本文整理汇总了PHP中SC_Query_Ex::begin方法的典型用法代码示例。如果您正苦于以下问题:PHP SC_Query_Ex::begin方法的具体用法?PHP SC_Query_Ex::begin怎么用?PHP SC_Query_Ex::begin使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类SC_Query_Ex
的用法示例。
在下文中一共展示了SC_Query_Ex::begin方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: revert
public function revert(array $migrations)
{
$migrations = $this->sort($migrations, SORT_DESC);
$reverteds = 0;
try {
foreach ($migrations as $migration) {
$this->query->begin();
if (!$this->storage->isAppliedVersion($migration->version)) {
$this->logger->log(sprintf('Revert migration skipped, Already reverted.: {system:"%s", version:"%s"}', $this->storage->system, $migration->version));
continue;
}
$migration->down();
$migration->applied = false;
$this->storage->markReverted($migration->version);
$this->query->commit();
$this->logger->log(sprintf('Revert migration successful: {system:"%s", version:"%s"}', $this->storage->system, $migration->version));
$reverteds++;
}
$this->query->commit();
} catch (Exception $e) {
if ($this->query->inTransaction()) {
$this->query->rollback();
}
$this->logger->log(sprintf('Revert migration failed: {system:"%s", version:"%s"}', $this->storage->system, $migration->version));
throw $e;
}
return $reverteds;
}
示例2: lfDeleteFavoriteProduct
function lfDeleteFavoriteProduct($customer_id, $product_id)
{
$objQuery = new SC_Query_Ex();
$count = $objQuery->count("dtb_customer_favorite_products", "customer_id = ? AND product_id = ?", array($customer_id, $product_id));
if ($count > 0) {
$objQuery->begin();
$objQuery->delete('dtb_customer_favorite_products', "customer_id = ? AND product_id = ?", array($customer_id, $product_id));
$objQuery->commit();
}
}
示例3: lfDelete
/**
* 受注テーブルの論理削除
*/
function lfDelete($arrOrderId)
{
$objQuery = new SC_Query_Ex();
if (!isset($arrOrderId) || !is_array($arrOrderId)) {
return false;
}
$arrUpdate = array('del_flg' => 1, 'update_date' => 'CURRENT_TIMESTAMP');
$objQuery->begin();
foreach ($arrOrderId as $orderId) {
$objQuery->update('dtb_order', $arrUpdate, 'order_id = ?', array($orderId));
}
$objQuery->commit();
$this->tpl_onload = "window.alert('選択項目を削除しました。');";
return true;
}
示例4: action
/**
* Page のアクション.
*
* @return void
*/
function action()
{
$objDb = new SC_Helper_DB_Ex();
$objFormParam = new SC_FormParam_Ex();
// 入力パラメーター初期化
$this->initParam($objFormParam);
$objFormParam->setParam($_POST);
$objFormParam->convParam();
switch ($this->getMode()) {
// カテゴリー登録/編集実行
case 'edit':
$category_id = $objFormParam->getValue('category_id');
if ($category_id == '') {
$this->doRegister($objFormParam);
} else {
$this->doEdit($objFormParam);
}
break;
// 入力ボックスへ編集対象のカテゴリ名をセット
// 入力ボックスへ編集対象のカテゴリ名をセット
case 'pre_edit':
$this->doPreEdit($objFormParam);
break;
// カテゴリ削除
// カテゴリ削除
case 'delete':
$this->doDelete($objFormParam, $objDb);
break;
// 表示順を上へ
// 表示順を上へ
case 'up':
$this->doUp($objFormParam);
break;
// 表示順を下へ
// 表示順を下へ
case 'down':
$this->doDown($objFormParam);
break;
// XXX 使われていないコード?
// XXX 使われていないコード?
case 'moveByDnD':
// DnDしたカテゴリと移動先のセットを分解する
$keys = explode("-", $_POST['keySet']);
if ($keys[0] && $keys[1]) {
$objQuery = new SC_Query_Ex();
$objQuery->begin();
// 移動したデータのrank、level、parent_category_idを取得
$rank = $objQuery->get('rank', "dtb_category", "category_id = ?", array($keys[0]));
$level = $objQuery->get('level', "dtb_category", "category_id = ?", array($keys[0]));
$parent = $objQuery->get("parent_category_id", "dtb_category", "category_id = ?", array($keys[0]));
// 同一level内のrank配列を作成
$objQuery->setOption("ORDER BY rank DESC");
if ($level == 1) {
// 第1階層の時
$arrRet = $objQuery->select('rank', "dtb_category", "level = ?", array($level));
} else {
// 第2階層以下の時
$arrRet = $objQuery->select('rank', "dtb_category", "level = ? AND parent_category_id = ?", array($level, $parent));
}
for ($i = 0; $i < sizeof($arrRet); $i++) {
$rankAry[$i + 1] = $arrRet[$i]['rank'];
}
// 移動したデータのグループ内データ数
$my_count = $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $keys[0]);
if ($rankAry[$keys[1]] > $rank) {
// データが今の位置より上がった時
$up_count = $rankAry[$keys[1]] - $rank;
$decAry = $objQuery->select("category_id", "dtb_category", "level = ? AND rank > ? AND rank <= ?", array($level, $rank, $rankAry[$keys[1]]));
foreach ($decAry as $value) {
// 上のグループから減算
$this->lfDownRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $value["category_id"], $my_count);
}
// 自分のグループに加算
$this->lfUpRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $keys[0], $up_count);
} else {
if ($rankAry[$keys[1]] < $rank) {
// データが今の位置より下がった時
$down_count = 0;
$incAry = $objQuery->select("category_id", "dtb_category", "level = ? AND rank < ? AND rank >= ?", array($level, $rank, $rankAry[$keys[1]]));
foreach ($incAry as $value) {
// 下のグループに加算
$this->lfUpRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $value["category_id"], $my_count);
// 合計減算値
$down_count += $this->lfCountChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $value["category_id"]);
}
// 自分のグループから減算
$this->lfDownRankChilds($objQuery, "dtb_category", "parent_category_id", "category_id", $keys[0], $down_count);
}
}
$objQuery->commit();
}
break;
// カテゴリツリークリック時
// カテゴリツリークリック時
case 'tree':
//.........这里部分代码省略.........