EC−CUBE2.13 MySQL
2017.02.20ものすごく久しぶりにEC−CUBEをさわる機会ができました。
原因はローカル環境のMySQLのバージョンに関連することはすぐに予想できたため、少し調べてみました。
修正部分は /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php の最終ブロックの1行のみ。
MySQLのデフォルトストレージエンジンはMySQL 5.5 からInnoDB。(これ以前はMyISAM)
エラーメッセージで表示されている storage_engine は下記ページの通り、MySQL 5.7.5 で削除されており、現在は default_storage_engine を使用する。
storage_engine: This variable is deprecated and was removed in MySQL 5.7.5. Use default_stor…
Error Message
Diff
SC_DB_DBFactory_MYSQL.php (original)
SC_DB_DBFactory_MYSQL.php (fixed)
▼▼▼ デバッグ情報ここから ▼▼▼ http://localhost/ec−cube/ SERVER_ADDR: ::1 REMOTE_ADDR: ::1 USER_AGENT: Mozilla/5.0 (Windows NT 6.3; rv:36.0) Gecko/20100101 Firefox/36.04 Fatal error(E_USER_ERROR): DB処理でエラーが発生しました。 SQL: [SET SESSION storage_engine = InnoDB] MDB2 Error: unknown error _doQuery: [Error message: Could not execute statement] [Last executed query: PREPARE mdb2_statement_mysql_1d3e8e86d15947fd40fdd35103c12a8dfc50ff2b2 FROM 'SET SESSION storage_engine = InnoDB'] [Native code: 1193] [Native message: Unknown system variable 'storage_engine'] on [/htdocs/ec-cube/data/class/SC_Query.php(1095)] /htdocs/ec-cube/index.php(23): require_once /htdocs/ec-cube/require.php(35): require_once /htdocs/ec-cube/data/require_base.php(45): SC_SessionFactory_UseCookie->initSession /htdocs/ec-cube/data/class/sessionfactory/SC_SessionFactory_UseCookie.php(53): session_start (): SC_Helper_Session->sfSessRead /htdocs/ec-cube/data/class/helper/SC_Helper_Session.php(69): SC_Query::getSingletonInstance /htdocs/ec-cube/data/class/SC_Query.php(105): SC_Query->__construct /htdocs/ec-cube/data/class/SC_Query.php(88): SC_DB_DBFactory_MYSQL->initObjQuery /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php(365): SC_Query->exec /htdocs/ec-cube/data/class/SC_Query.php(255): SC_Query->query /htdocs/ec-cube/data/class/SC_Query.php(868): SC_Query->prepare /htdocs/ec-cube/data/class/SC_Query.php(1024): SC_Query->error /htdocs/ec-cube/data/class/SC_Query.php(1095): trigger_error ▲▲▲ デバッグ情報ここまで ▲▲▲
$ diff -u /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL_old.php /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php --- /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL_old.php 2017-02-20 22:19:36.000000000 +0900 +++ /htdocs/ec-cube/data/class/db/dbfactory/SC_DB_DBFactory_MYSQL.php 2017-02-20 22:20:07.000000000 +0900 @@ -360,7 +360,7 @@ */ public function initObjQuery(SC_Query &$objQuery) { - $objQuery->exec('SET SESSION storage_engine = InnoDB'); + $objQuery->exec('SET SESSION default_storage_engine = InnoDB'); $objQuery->exec("SET SESSION sql_mode = 'ANSI'"); } }
<?php /* * This file is part of EC-CUBE * * Copyright(c) 2000-2014 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. */ /** * MySQL 固有の処理をするクラス. * * このクラスを直接インスタンス化しないこと. * 必ず SC_DB_DBFactory クラスを経由してインスタンス化する. * また, SC_DB_DBFactory クラスの関数を必ずオーバーライドしている必要がある. * * @package DB * @author LOCKON CO.,LTD. * @version $Id:SC_DB_DBFactory_MYSQL.php 15267 2007-08-09 12:31:52Z nanasess $ */ class SC_DB_DBFactory_MYSQL extends SC_DB_DBFactory { /** SC_Query インスタンス */ public $objQuery; /** * DBのバージョンを取得する. * * @param string $dsn データソース名 * @return string データベースのバージョン */ public function sfGetDBVersion($dsn = '') { $objQuery =& SC_Query_Ex::getSingletonInstance($dsn); $val = $objQuery->getOne('select version()'); return 'MySQL ' . $val; } /** * MySQL 用の SQL 文に変更する. * * @access private * @param string $sql SQL 文 * @return string MySQL 用に置換した SQL 文 */ public function sfChangeMySQL($sql) { // 改行、タブを1スペースに変換 $sql = preg_replace("/[rnt]/", ' ', $sql); // ILIKE検索をLIKE検索に変換する $sql = $this->sfChangeILIKE($sql); // RANDOM()をRAND()に変換する $sql = $this->sfChangeRANDOM($sql); // TRUNCをTRUNCATEに変換する $sql = $this->sfChangeTrunc($sql); // ARRAY_TO_STRINGをGROUP_CONCATに変換する $sql = $this->sfChangeArrayToString($sql); return $sql; } /** * 文字コード情報を取得する * * @return array 文字コード情報 */ public function getCharSet() { $objQuery =& SC_Query_Ex::getSingletonInstance(); $arrRet = $objQuery->getAll("SHOW VARIABLES LIKE 'char%'"); return $arrRet; } /** * 昨日の売上高・売上件数を算出する SQL を返す. * * @param string $method SUM または COUNT * @return string 昨日の売上高・売上件数を算出する SQL */ public function getOrderYesterdaySql($method) { return 'SELECT ' . $method . '(total) FROM dtb_order ' . 'WHERE del_flg = 0 ' . 'AND cast(create_date as date) = DATE_ADD(current_date, interval -1 day) ' . 'AND status <> ' . ORDER_CANCEL; } /** * 当月の売上高・売上件数を算出する SQL を返す. * * @param string $method SUM または COUNT * @return string 当月の売上高・売上件数を算出する SQL */ public function getOrderMonthSql($method) { return 'SELECT '.$method.'(total) FROM dtb_order ' . 'WHERE del_flg = 0 ' . "AND date_format(create_date, '%Y/%m') = ? " . "AND date_format(create_date, '%Y/%m/%d') <> date_format(CURRENT_TIMESTAMP, '%Y/%m/%d') " . 'AND status <> ' . ORDER_CANCEL; } /** * 昨日のレビュー書き込み件数を算出する SQL を返す. * * @return string 昨日のレビュー書き込み件数を算出する SQL */ public function getReviewYesterdaySql() { return 'SELECT COUNT(*) FROM dtb_review AS A ' . 'LEFT JOIN dtb_products AS B ' . 'ON A.product_id = B.product_id ' . 'WHERE A.del_flg = 0 ' . 'AND B.del_flg = 0 ' . 'AND cast(A.create_date as date) = DATE_ADD(current_date, interval -1 day) ' . 'AND cast(A.create_date as date) != current_date'; } /** * メール送信履歴の start_date の検索条件の SQL を返す. * * @return string 検索条件の SQL */ public function getSendHistoryWhereStartdateSql() { return 'start_date BETWEEN date_add(CURRENT_TIMESTAMP,INTERVAL -5 minute) AND date_add(CURRENT_TIMESTAMP,INTERVAL 5 minute)'; } /** * ダウンロード販売の検索条件の SQL を返す. * * @param string $dtb_order_alias * @return string 検索条件の SQL */ public function getDownloadableDaysWhereSql($dtb_order_alias = 'dtb_order') { $sql = <<< __EOS__ ( SELECT IF ( (SELECT d1.downloadable_days_unlimited FROM dtb_baseinfo d1) = 1 AND $dtb_order_alias.payment_date IS NOT NULL, 1, IF( DATE(CURRENT_TIMESTAMP) <= DATE(DATE_ADD($dtb_order_alias.payment_date, INTERVAL (SELECT downloadable_days FROM dtb_baseinfo) DAY)), 1, 0) ) ) __EOS__; return $sql; } /** * 売上集計の期間別集計のSQLを返す * * @param mixed $type * @return string 検索条件のSQL */ public function getOrderTotalDaysWhereSql($type) { switch ($type) { case 'month': $format = '%Y-%m'; break; case 'year': $format = '%Y'; break; case 'wday': $format = '%a'; break; case 'hour': $format = '%H'; break; default: $format = '%Y-%m-%d'; break; } return " date_format(create_date, '".$format."') AS str_date, COUNT(order_id) AS total_order, SUM(CASE WHEN order_sex = 1 THEN 1 ELSE 0 END) AS men, SUM(CASE WHEN order_sex = 2 THEN 1 ELSE 0 END) AS women, SUM(CASE WHEN customer_id <> 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_member, SUM(CASE WHEN customer_id <> 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_member, SUM(CASE WHEN customer_id = 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_nonmember, SUM(CASE WHEN customer_id = 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_nonmember, SUM(total) AS total, AVG(total) AS total_average"; } /** * 売上集計の年代別集計の年代抽出部分のSQLを返す * * @return string 年代抽出部分の SQL */ public function getOrderTotalAgeColSql() { return 'TRUNC((YEAR(create_date) - YEAR(order_birth)) - (RIGHT(create_date, 5) < RIGHT(order_birth, 5)), -1)'; } /** * 文字列連結を行う. * * @param string[] $columns 連結を行うカラム名 * @return string 連結後の SQL 文 */ public function concatColumn($columns) { $sql = 'concat('; $i = 0; $total = count($columns); foreach ($columns as $column) { $sql .= $column; if ($i < $total -1) { $sql .= ', '; } $i++; } $sql .= ')'; return $sql; } /** * テーブルを検索する. * * 引数に部分一致するテーブル名を配列で返す. * * @param string $expression 検索文字列 * @return array テーブル名の配列 */ public function findTableNames($expression = '') { $objQuery =& SC_Query_Ex::getSingletonInstance(); $sql = 'SHOW TABLES LIKE '. $objQuery->quote('%' . $expression . '%'); $arrColList = $objQuery->getAll($sql); $arrColList = SC_Utils_Ex::sfSwapArray($arrColList, false); return $arrColList[0]; } /** * ILIKE句 を LIKE句へ変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeILIKE($sql) { $changesql = preg_replace('/(^|[^w])ILIKE([^w]|$)/i', '$1LIKE$2', $sql); return $changesql; } /** * RANDOM() を RAND() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeRANDOM($sql) { $changesql = preg_replace('/(^|[^w])RANDOM(/i', '$1RAND(', $sql); return $changesql; } /** * TRUNC() を TRUNCATE() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeTrunc($sql) { $changesql = preg_replace('/(^|[^w])TRUNC([^w]|$)/i', '$1TRUNCATE$2', $sql); return $changesql; } /** * ARRAY_TO_STRING(ARRAY(A),B) を GROUP_CONCAT() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeArrayToString($sql) { if (strpos(strtoupper($sql), 'ARRAY_TO_STRING') !== FALSE) { preg_match_all('/ARRAY_TO_STRING.*?(.*?ARRAY(.*?SELECT (.+?) FROM (.+?) WHERE (.+?)).*?,.*?'(.+?)'.*?)/is', $sql, $match, PREG_SET_ORDER); foreach ($match as $item) { $replace = 'GROUP_CONCAT(' . $item[1] . ' SEPARATOR '' . $item[4] . '') FROM ' . $item[2] . ' WHERE ' . $item[3]; $sql = str_replace($item[0], $replace, $sql); } } return $sql; } /** * インデックス作成の追加定義を取得する * * 引数に部分一致するテーブル名を配列で返す. * * @param string $table 対象テーブル名 * @param string $name 対象カラム名 * @return array インデックス設定情報配列 */ public function sfGetCreateIndexDefinition($table, $name, $definition) { $objQuery =& SC_Query_Ex::getSingletonInstance(); $arrTblInfo = $objQuery->getTableInfo($table); foreach ($arrTblInfo as $fieldInfo) { if (array_key_exists($fieldInfo['name'], $definition['fields'])) { if ($fieldInfo['nativetype'] == 'text') { // TODO: text型フィールドの場合に255文字以内決めうちでインデックス列のサイズとして // 指定して良いか確認は必要。 $definition['fields'][$fieldInfo['name']]['length'] = '255'; } } } return $definition; } /** * 擬似表を表すSQL文(FROM 句)を取得する * * @return string */ public function getDummyFromClauseSql() { return 'FROM DUAL'; } /** * 各 DB に応じた SC_Query での初期化を行う * * @param SC_Query $objQuery SC_Query インスタンス * @return void */ public function initObjQuery(SC_Query &$objQuery) { $objQuery->exec('SET SESSION storage_engine = InnoDB'); $objQuery->exec("SET SESSION sql_mode = 'ANSI'"); } }
<?php /* * This file is part of EC-CUBE * * Copyright(c) 2000-2014 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. */ /** * MySQL 固有の処理をするクラス. * * このクラスを直接インスタンス化しないこと. * 必ず SC_DB_DBFactory クラスを経由してインスタンス化する. * また, SC_DB_DBFactory クラスの関数を必ずオーバーライドしている必要がある. * * @package DB * @author LOCKON CO.,LTD. * @version $Id:SC_DB_DBFactory_MYSQL.php 15267 2007-08-09 12:31:52Z nanasess $ */ class SC_DB_DBFactory_MYSQL extends SC_DB_DBFactory { /** SC_Query インスタンス */ public $objQuery; /** * DBのバージョンを取得する. * * @param string $dsn データソース名 * @return string データベースのバージョン */ public function sfGetDBVersion($dsn = '') { $objQuery =& SC_Query_Ex::getSingletonInstance($dsn); $val = $objQuery->getOne('select version()'); return 'MySQL ' . $val; } /** * MySQL 用の SQL 文に変更する. * * @access private * @param string $sql SQL 文 * @return string MySQL 用に置換した SQL 文 */ public function sfChangeMySQL($sql) { // 改行、タブを1スペースに変換 $sql = preg_replace("/[rnt]/", ' ', $sql); // ILIKE検索をLIKE検索に変換する $sql = $this->sfChangeILIKE($sql); // RANDOM()をRAND()に変換する $sql = $this->sfChangeRANDOM($sql); // TRUNCをTRUNCATEに変換する $sql = $this->sfChangeTrunc($sql); // ARRAY_TO_STRINGをGROUP_CONCATに変換する $sql = $this->sfChangeArrayToString($sql); return $sql; } /** * 文字コード情報を取得する * * @return array 文字コード情報 */ public function getCharSet() { $objQuery =& SC_Query_Ex::getSingletonInstance(); $arrRet = $objQuery->getAll("SHOW VARIABLES LIKE 'char%'"); return $arrRet; } /** * 昨日の売上高・売上件数を算出する SQL を返す. * * @param string $method SUM または COUNT * @return string 昨日の売上高・売上件数を算出する SQL */ public function getOrderYesterdaySql($method) { return 'SELECT ' . $method . '(total) FROM dtb_order ' . 'WHERE del_flg = 0 ' . 'AND cast(create_date as date) = DATE_ADD(current_date, interval -1 day) ' . 'AND status <> ' . ORDER_CANCEL; } /** * 当月の売上高・売上件数を算出する SQL を返す. * * @param string $method SUM または COUNT * @return string 当月の売上高・売上件数を算出する SQL */ public function getOrderMonthSql($method) { return 'SELECT '.$method.'(total) FROM dtb_order ' . 'WHERE del_flg = 0 ' . "AND date_format(create_date, '%Y/%m') = ? " . "AND date_format(create_date, '%Y/%m/%d') <> date_format(CURRENT_TIMESTAMP, '%Y/%m/%d') " . 'AND status <> ' . ORDER_CANCEL; } /** * 昨日のレビュー書き込み件数を算出する SQL を返す. * * @return string 昨日のレビュー書き込み件数を算出する SQL */ public function getReviewYesterdaySql() { return 'SELECT COUNT(*) FROM dtb_review AS A ' . 'LEFT JOIN dtb_products AS B ' . 'ON A.product_id = B.product_id ' . 'WHERE A.del_flg = 0 ' . 'AND B.del_flg = 0 ' . 'AND cast(A.create_date as date) = DATE_ADD(current_date, interval -1 day) ' . 'AND cast(A.create_date as date) != current_date'; } /** * メール送信履歴の start_date の検索条件の SQL を返す. * * @return string 検索条件の SQL */ public function getSendHistoryWhereStartdateSql() { return 'start_date BETWEEN date_add(CURRENT_TIMESTAMP,INTERVAL -5 minute) AND date_add(CURRENT_TIMESTAMP,INTERVAL 5 minute)'; } /** * ダウンロード販売の検索条件の SQL を返す. * * @param string $dtb_order_alias * @return string 検索条件の SQL */ public function getDownloadableDaysWhereSql($dtb_order_alias = 'dtb_order') { $sql = <<< __EOS__ ( SELECT IF ( (SELECT d1.downloadable_days_unlimited FROM dtb_baseinfo d1) = 1 AND $dtb_order_alias.payment_date IS NOT NULL, 1, IF( DATE(CURRENT_TIMESTAMP) <= DATE(DATE_ADD($dtb_order_alias.payment_date, INTERVAL (SELECT downloadable_days FROM dtb_baseinfo) DAY)), 1, 0) ) ) __EOS__; return $sql; } /** * 売上集計の期間別集計のSQLを返す * * @param mixed $type * @return string 検索条件のSQL */ public function getOrderTotalDaysWhereSql($type) { switch ($type) { case 'month': $format = '%Y-%m'; break; case 'year': $format = '%Y'; break; case 'wday': $format = '%a'; break; case 'hour': $format = '%H'; break; default: $format = '%Y-%m-%d'; break; } return " date_format(create_date, '".$format."') AS str_date, COUNT(order_id) AS total_order, SUM(CASE WHEN order_sex = 1 THEN 1 ELSE 0 END) AS men, SUM(CASE WHEN order_sex = 2 THEN 1 ELSE 0 END) AS women, SUM(CASE WHEN customer_id <> 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_member, SUM(CASE WHEN customer_id <> 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_member, SUM(CASE WHEN customer_id = 0 AND order_sex = 1 THEN 1 ELSE 0 END) AS men_nonmember, SUM(CASE WHEN customer_id = 0 AND order_sex = 2 THEN 1 ELSE 0 END) AS women_nonmember, SUM(total) AS total, AVG(total) AS total_average"; } /** * 売上集計の年代別集計の年代抽出部分のSQLを返す * * @return string 年代抽出部分の SQL */ public function getOrderTotalAgeColSql() { return 'TRUNC((YEAR(create_date) - YEAR(order_birth)) - (RIGHT(create_date, 5) < RIGHT(order_birth, 5)), -1)'; } /** * 文字列連結を行う. * * @param string[] $columns 連結を行うカラム名 * @return string 連結後の SQL 文 */ public function concatColumn($columns) { $sql = 'concat('; $i = 0; $total = count($columns); foreach ($columns as $column) { $sql .= $column; if ($i < $total -1) { $sql .= ', '; } $i++; } $sql .= ')'; return $sql; } /** * テーブルを検索する. * * 引数に部分一致するテーブル名を配列で返す. * * @param string $expression 検索文字列 * @return array テーブル名の配列 */ public function findTableNames($expression = '') { $objQuery =& SC_Query_Ex::getSingletonInstance(); $sql = 'SHOW TABLES LIKE '. $objQuery->quote('%' . $expression . '%'); $arrColList = $objQuery->getAll($sql); $arrColList = SC_Utils_Ex::sfSwapArray($arrColList, false); return $arrColList[0]; } /** * ILIKE句 を LIKE句へ変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeILIKE($sql) { $changesql = preg_replace('/(^|[^w])ILIKE([^w]|$)/i', '$1LIKE$2', $sql); return $changesql; } /** * RANDOM() を RAND() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeRANDOM($sql) { $changesql = preg_replace('/(^|[^w])RANDOM(/i', '$1RAND(', $sql); return $changesql; } /** * TRUNC() を TRUNCATE() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeTrunc($sql) { $changesql = preg_replace('/(^|[^w])TRUNC([^w]|$)/i', '$1TRUNCATE$2', $sql); return $changesql; } /** * ARRAY_TO_STRING(ARRAY(A),B) を GROUP_CONCAT() に変換する. * * @access private * @param string $sql SQL文 * @return string 変換後の SQL 文 */ public function sfChangeArrayToString($sql) { if (strpos(strtoupper($sql), 'ARRAY_TO_STRING') !== FALSE) { preg_match_all('/ARRAY_TO_STRING.*?(.*?ARRAY(.*?SELECT (.+?) FROM (.+?) WHERE (.+?)).*?,.*?'(.+?)'.*?)/is', $sql, $match, PREG_SET_ORDER); foreach ($match as $item) { $replace = 'GROUP_CONCAT(' . $item[1] . ' SEPARATOR '' . $item[4] . '') FROM ' . $item[2] . ' WHERE ' . $item[3]; $sql = str_replace($item[0], $replace, $sql); } } return $sql; } /** * インデックス作成の追加定義を取得する * * 引数に部分一致するテーブル名を配列で返す. * * @param string $table 対象テーブル名 * @param string $name 対象カラム名 * @return array インデックス設定情報配列 */ public function sfGetCreateIndexDefinition($table, $name, $definition) { $objQuery =& SC_Query_Ex::getSingletonInstance(); $arrTblInfo = $objQuery->getTableInfo($table); foreach ($arrTblInfo as $fieldInfo) { if (array_key_exists($fieldInfo['name'], $definition['fields'])) { if ($fieldInfo['nativetype'] == 'text') { // TODO: text型フィールドの場合に255文字以内決めうちでインデックス列のサイズとして // 指定して良いか確認は必要。 $definition['fields'][$fieldInfo['name']]['length'] = '255'; } } } return $definition; } /** * 擬似表を表すSQL文(FROM 句)を取得する * * @return string */ public function getDummyFromClauseSql() { return 'FROM DUAL'; } /** * 各 DB に応じた SC_Query での初期化を行う * * @param SC_Query $objQuery SC_Query インスタンス * @return void */ public function initObjQuery(SC_Query &$objQuery) { $objQuery->exec('SET SESSION default_storage_engine = InnoDB'); $objQuery->exec("SET SESSION sql_mode = 'ANSI'"); } }