當前位置: 首頁>>代碼示例>>PHP>>正文


PHP SqlHelper::arrToCase方法代碼示例

本文整理匯總了PHP中SqlHelper::arrToCase方法的典型用法代碼示例。如果您正苦於以下問題:PHP SqlHelper::arrToCase方法的具體用法?PHP SqlHelper::arrToCase怎麽用?PHP SqlHelper::arrToCase使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在SqlHelper的用法示例。


在下文中一共展示了SqlHelper::arrToCase方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: actionSorting

 public function actionSorting()
 {
     if (isset($_POST['tree'])) {
         $model = new Category();
         $this->performAjaxValidation($model);
         //при сортировке дерева параметры корня измениться не могут,
         //поэтоtму его вообще сохранять не будем
         $data = json_decode($_POST['tree']);
         array_shift($data);
         //получаем большие case для update
         $update = array();
         $nestedSortableFields = array('depth' => Category::DEPTH, 'left' => Category::LFT, 'right' => Category::RGT);
         foreach ($nestedSortableFields as $key => $field) {
             $update_data = CHtml::listData($data, 'item_id', $key);
             $update[] = "{$field} = " . SqlHelper::arrToCase('id', $update_data);
         }
         //обновляем всю таблицу, кроме рута
         $condition = Category::DEPTH . " > 1";
         $command = Yii::app()->db->commandBuilder->createSqlCommand("UPDATE `{$model->tableName()}` SET " . implode(', ', $update) . " WHERE {$condition}");
         $command->execute();
         echo CJSON::encode(array('status' => 'ok', 'redirect' => $this->createUrl('manage')));
         Yii::app()->end();
     }
     $this->render('sorting');
 }
開發者ID:nizsheanez,項目名稱:documentation,代碼行數:25,代碼來源:DocumentationAdminController.php

示例2: actionSorting

 public function actionSorting($root_id, $menu_id)
 {
     if (isset($_POST['tree'])) {
         $model = new MenuSection();
         $this->performAjaxValidation($model);
         //при сортировке дерева параметры корня измениться не могут,
         //поэтоtму его вообще сохранять не будем
         $data = json_decode($_POST['tree']);
         array_shift($data);
         //получаем большие case для update
         $update = [];
         $js_to_sql_mapping = ['depth' => 'level', 'left' => 'left', 'right' => 'right'];
         foreach ($js_to_sql_mapping as $js_field => $field) {
             $update_data = CHtml::listData($data, 'item_id', $js_field);
             $update[] = "t.{$field} = " . SqlHelper::arrToCase('id', $update_data, 't');
         }
         $in = implode(', ', array_values(CHtml::listData($data, 'item_id', 'item_id')));
         $condition = "t.level > 1";
         $command = Yii::app()->db->commandBuilder->createSqlCommand("UPDATE `{$model->tableName()}` as t SET " . implode(', ', $update) . " WHERE {$condition} AND t.id IN ({$in})");
         $command->execute();
         echo CJSON::encode(['status' => 'ok', 'redirect' => $this->createUrl('manage', ['menu_id' => $menu_id])]);
         Yii::app()->end();
     }
     $this->render('sorting', ['root_id' => $root_id, 'menu_id' => $menu_id]);
 }
開發者ID:blindest,項目名稱:Yii-CMS-2.0,代碼行數:25,代碼來源:MenuSectionAdminController.php

示例3: run

 public function run()
 {
     $model = $this->model;
     $class = get_class($model);
     if (isset($_POST['tree'])) {
         $this->controller->performAjaxValidation($model);
         //при сортировке дерева параметры корня измениться не могут,
         //поэтоtму его вообще сохранять не будем
         $data = json_decode($_POST['tree']);
         array_shift($data);
         //получаем большие case для update
         $update = array();
         $nestedSortableFields = array('depth' => $class::DEPTH, 'left' => $class::LFT, 'right' => $class::RGT);
         foreach ($nestedSortableFields as $key => $field) {
             $update_data = CHtml::listData($data, 'item_id', $key);
             if ($key == $class::DEPTH) {
                 foreach ($update_data as $key => $val) {
                     $update_data[$key]++;
                 }
             }
             $update[] = "{$field} = " . SqlHelper::arrToCase('id', $update_data);
         }
         //обновляем всю таблицу, кроме рута
         $condition = $class::DEPTH . " > 1";
         $command = Yii::app()->db->createCommand("UPDATE `{$model->tableName()}` SET " . implode(', ', $update) . " WHERE {$condition}");
         $command->execute();
         $this->controller->forward($this->forwardRoute, true);
     }
     $this->controller->render('sort', array('model' => $model, 'class' => $class));
 }
開發者ID:nizsheanez,項目名稱:kur.ru,代碼行數:30,代碼來源:ActionSort.php

示例4: run

 public function run()
 {
     $ids = array_reverse($_POST['File']);
     $files = new MediaFile('sort');
     $case = SqlHelper::arrToCase('id', array_flip($ids), 't');
     $arr = implode(',', $ids);
     Yii::app()->db->getCommandBuilder()->createSqlCommand("UPDATE {$files->tableName()} AS t SET t.order = {$case} WHERE t.id IN ({$arr})")->execute();
 }
開發者ID:blindest,項目名稱:Yii-CMS-2.0,代碼行數:8,代碼來源:SavePriorityAction.php

示例5: setPositions

 public function setPositions($ids, $column, $start)
 {
     $model = $this->getOwner();
     $table = $model->tableName();
     $priorities = array();
     foreach ($ids as $id) {
         $priorities[$id] = $start--;
     }
     $case = SqlHelper::arrToCase('id', $priorities, $model->getTableAlias());
     $in = SqlHelper::in('id', $ids, $model->getTableAlias());
     $c = Yii::app()->db->commandBuilder->createSqlCommand("UPDATE {$table} AS t SET t.{$column} = {$case} WHERE {$in}");
     $c->execute();
 }
開發者ID:blindest,項目名稱:Yii-CMS-2.0,代碼行數:13,代碼來源:SortableBehavior.php

示例6: setPositions

 public function setPositions($ids, $column, $start)
 {
     list($table, $fk1, $fk2) = SqlHelper::parseManyMany($this->owner, $this->relation);
     $model = $this->getOwner();
     $table = $model->tableName();
     $priorities = array();
     foreach ($ids as $id) {
         $priorities[$id] = $start--;
     }
     $case = SqlHelper::arrToCase('id', $priorities, $model->getTableAlias());
     $c = Yii::app()->db->commandBuilder->createSqlCommand("UPDATE {$table} AS t SET t.{$column} = {$case}");
     $c->execute();
 }
開發者ID:nizsheanez,項目名稱:alp.ru,代碼行數:13,代碼來源:ManyManySortableBehavior.php


注:本文中的SqlHelper::arrToCase方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。