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


PHP ContentModel::get_model_table_by_id方法代碼示例

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


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

示例1: get_archive_by_id

 /**
  * 根據content_archives_id獲取文檔
  * @param mixed $content_archives_id    文檔編號
  * @return string $content_archives     文檔
  */
 public static function get_archive_by_id($content_archives_id, $allow_cache = false)
 {
     $content_archives_name = '';
     if (!$content_archives_id) {
         return '';
     }
     //有開啟緩存功能,則從緩存中取數據, 如果有數據,則直接返回結果
     if ($allow_cache && Yii::app()->cache) {
         $_cache_key = 'content.archive.row.' . $content_archives_id;
         $_r = Yii::app()->cache->get($_cache_key);
         if ($_r && is_array($_r)) {
             return $_r;
         }
     }
     $cmd = Yii::app()->db->createCommand();
     $cmd->select('a.content_archives_id, ac.content_model_id, m.content_model_name, ac.class_id, ac.class_name, a.content_archives_subject, a.content_archives_color, a.content_archives_short_subject, a.content_archives_flag, a.content_archives_jump_url, a.content_archives_source, a.content_archives_author, a.content_archives_thumb, a.content_archives_keywords, a.content_archives_summary, a.content_archives_status, a.content_archives_rank, a.content_archives_pubtime, a.content_archives_lasttime, a.content_archives_dateline')->from('{{content_archives}} a')->join('{{content_archives_classes_relating}} acr', 'acr.content_archives_id=a.content_archives_id')->join('{{content_archives_classes}} ac', 'ac.class_id=acr.class_id')->join('{{content_model}} m', 'm.content_model_id=ac.content_model_id')->where('a.content_archives_id=:content_archives_id', array('content_archives_id' => $content_archives_id));
     $_r = $cmd->queryRow();
     if ($_r) {
         //附加表結構
         $_r['content_model_colums'] = ContentModel::get_model_table_by_id($_r['content_model_id']);
         //附加表數據
         $content_model_identify = ContentModel::get_model_identify_by_id($_r['content_model_id']);
         $_sql = "SELECT * FROM {{content_addons{$content_model_identify}}} WHERE content_archives_id=:content_archives_id LIMIT 0, 1";
         $cmd = Yii::app()->db->createCommand($_sql);
         $cmd->bindValue(':content_archives_id', $content_archives_id);
         $_a_r = $cmd->queryRow();
         if (is_array($_a_r)) {
             //
             foreach ($_r['content_model_colums'] as $_k => $_v) {
                 if ($_v['content_model_field_type'] == ContentModelField::DATA_TYPE_CHECKBOX) {
                     $_a_r[$_v['content_model_field_identify']] = unserialize($_a_r[$_v['content_model_field_identify']]);
                 }
             }
             $_r = array_merge($_r, $_a_r);
         }
         unset($_a_r);
         //自定義屬性
         $_r['content_archives_flag'] = explode(',', $_r['content_archives_flag']);
         //文檔欄目
         $_sql = "SELECT c.*\n\t\t\t\t\tFROM {{content_archives_classes_relating}} cr\n\t\t\t\t\tINNER JOIN {{content_archives_classes}} c ON c.class_id = cr.class_id \n\t\t\t\t\tWHERE cr.content_archives_id=:content_archives_id";
         $_r['content_archives_classes'] = Yii::app()->db->createCommand($_sql)->queryAll(true, array(':content_archives_id' => $content_archives_id));
         //文檔標簽
         $_sql = "SELECT tags_id, tags_name\n\t\t\t\t\tFROM {{content_archives_tags}}\n\t\t\t\t\tWHERE content_archives_id=:content_archives_id\n\t\t\t\t\tORDER BY tags_id ASC";
         $_r['content_archives_tags'] = Yii::app()->db->createCommand($_sql)->queryAll(true, array(':content_archives_id' => $content_archives_id));
     }
     //有開啟緩存,則把結果添加到緩存中
     if ($allow_cache && Yii::app()->cache) {
         $_cache_time_out = Setting::getSettingCache('GOODS_ROW_TIME_OUT');
         Yii::app()->cache->set($_cache_key, $_r, $_cache_time_out);
         unset($_cache_time_out, $_cache_key);
     }
     return $_r ? $_r : array();
 }
開發者ID:nbaiwan,項目名稱:yav,代碼行數:58,代碼來源:ContentArchives.php

示例2: actionUpdate

 public function actionUpdate($id)
 {
     $archive = ContentArchives::get_archive_by_id($id, false);
     //dump($archive);exit;
     if ($_SERVER['REQUEST_METHOD'] == 'POST') {
         if (!isset($_POST['Archive']) || !is_array($_POST['Archive'])) {
             $this->redirect[] = array('text' => '', 'href' => 'javascript:history.go(-1);');
             $this->message('發布文檔信息錯誤', self::MSG_ERROR, true);
         }
         if ($_POST['Archive']['content_archives_subject'] == '') {
             $this->redirect[] = array('text' => '', 'href' => 'javascript:history.go(-1);');
             $this->message('文檔標題不能為空', self::MSG_ERROR, true);
         }
         if (empty($_POST['Archive']['class_id']) || !is_array($_POST['Archive']['class_id'])) {
             $this->redirect[] = array('text' => '', 'href' => 'javascript:history.go(-1);');
             $this->message('請至少選擇一個文檔欄目', self::MSG_ERROR, true);
         } else {
             foreach ($_POST['Archive']['class_id'] as $_k => $_v) {
                 if (empty($_v)) {
                     unset($_POST['Archive']['class_id'][$_k]);
                 }
             }
             if (empty($_POST['Archive']['class_id'])) {
                 $this->redirect[] = array('text' => '', 'href' => 'javascript:history.go(-1);');
                 $this->message('請至少選擇一個文檔欄目', self::MSG_ERROR, true);
             }
         }
         /*if($_POST['Archive']['content_archives_body'] =='') {
         			$this->redirect[] = array(
         				'text' => '',
         				'href' => 'javascript:history.go(-1);',
         			);
         			$this->message('文檔內容不能為空', self::MSG_ERROR, true);
         		}*/
         //自定義屬性
         if (isset($_POST['Archive']['content_archives_flag']) && is_array($_POST['Archive']['content_archives_flag'])) {
             $_POST['Archive']['content_archives_flag'] = implode(',', $_POST['Archive']['content_archives_flag']);
         } else {
             $_POST['Archive']['content_archives_flag'] = '';
         }
         //發布時間
         $pubdate = $_POST['Archive']['content_archives_pubtime'] == '' ? $_SERVER['REQUEST_TIME'] : strtotime($_POST['Archive']['content_archives_pubtime']);
         $user = Yii::app()->user;
         $flag = Yii::app()->db->createCommand()->update('{{content_archives}}', array('content_archives_subject' => $_POST['Archive']['content_archives_subject'], 'content_archives_color' => $_POST['Archive']['content_archives_color'], 'content_archives_short_subject' => $_POST['Archive']['content_archives_short_subject'], 'content_archives_flag' => $_POST['Archive']['content_archives_flag'], 'content_archives_jump_url' => $_POST['Archive']['content_archives_jump_url'], 'content_archives_thumb' => $_POST['Archive']['content_archives_thumb'], 'content_archives_source' => $_POST['Archive']['content_archives_source'], 'content_archives_author' => $_POST['Archive']['content_archives_author'], 'content_archives_keywords' => $_POST['Archive']['content_archives_keywords'], 'content_archives_summary' => $_POST['Archive']['content_archives_summary'], 'content_archives_rank' => $_POST['Archive']['content_archives_rank'] ? intval($_POST['Archive']['content_archives_rank']) : 255, 'content_archives_pubtime' => $pubdate, 'content_archives_lasttime' => $_SERVER['REQUEST_TIME'], 'update_user_id' => $user->user_id), 'content_archives_id=:content_archives_id', array(':content_archives_id' => $id));
         if ($flag) {
             $content_archives_name = $_POST['Archive']['content_archives_name'];
             //文檔欄目
             $_POST['Archive']['class_id'] = array_unique($_POST['Archive']['class_id']);
             $_sql_addons = "";
             $_params = array(':content_archives_id' => $id);
             foreach ($_POST['Archive']['class_id'] as $_k => $_v) {
                 $_sql_addons .= $_sql_addons ? " OR class_id=:class_id{$_k}" : "class_id=:class_id{$_k}";
                 $_params[":class_id{$_k}"] = $_v;
             }
             //刪除多餘欄目
             $_sql = "DELETE FROM {{content_archives_classes_relating}} WHERE content_archives_id=:content_archives_id AND NOT ({$_sql_addons})";
             Yii::app()->db->createCommand($_sql)->execute($_params);
             //取出現有欄目
             $_sql = "SELECT class_id FROM {{content_archives_classes_relating}} WHERE content_archives_id=:content_archives_id AND ({$_sql_addons})";
             $_classes = Yii::app()->db->createCommand($_sql)->queryColumn($_params);
             //去除已存在庫中的欄目
             $_classes = array_diff($_POST['Archive']['class_id'], $_classes);
             //欄目入庫
             foreach ($_classes as $_k => $_v) {
                 Yii::app()->db->createCommand()->insert('{{content_archives_classes_relating}}', array('content_archives_id' => $id, 'class_id' => $_v));
             }
             //標簽處理
             $_sql_addons = "";
             $_params = array(':content_archives_id' => $id);
             $content_archives_tags = preg_split('/[,|,]/', $_POST['Archive']['content_archives_tags']);
             foreach ($content_archives_tags as $_k => $_v) {
                 $_sql_addons .= $_sql_addons ? " OR tags_name=:tags_name{$_k}" : "tags_name=:tags_name{$_k}";
                 $_params[":tags_name{$_k}"] = $_v;
             }
             //刪除多餘欄目
             $_sql = "DELETE FROM {{content_archives_tags}} WHERE content_archives_id=:content_archives_id AND NOT ({$_sql_addons})";
             Yii::app()->db->createCommand($_sql)->execute($_params);
             //取出現有欄目
             $_sql = "SELECT tags_name FROM {{content_archives_tags}} WHERE content_archives_id=:content_archives_id AND ({$_sql_addons})";
             $_tags = Yii::app()->db->createCommand($_sql)->queryColumn($_params);
             //去除已存在庫中的欄目
             $_tags = array_diff($content_archives_tags, $_tags);
             //欄目入庫
             foreach ($_tags as $_k => $_v) {
                 Yii::app()->db->createCommand()->insert('{{content_archives_tags}}', array('content_archives_id' => $id, 'tags_name' => $_v));
             }
             //縮略圖
             //附加表信息
             $_model = ContentModel::get_model_by_id($archive['content_model_id']);
             $_columns = ContentModel::get_model_table_by_id($_model['content_model_id']);
             $_table_name = "{{content_addons{$_model['content_model_identify']}}}";
             $data = array();
             foreach ($_columns as $_k => $_v) {
                 if ($_v['content_model_field_type'] == ContentModelField::DATA_TYPE_CHECKBOX) {
                     $data[$_v['content_model_field_identify']] = serialize($_POST['Archive'][$_v['content_model_field_identify']]);
                 } else {
                     $data[$_v['content_model_field_identify']] = $_POST['Archive'][$_v['content_model_field_identify']];
                 }
             }
             Yii::app()->db->createCommand()->update($_table_name, $data, 'content_archives_id=:content_archives_id', array(':content_archives_id' => $id));
//.........這裏部分代碼省略.........
開發者ID:nbaiwan,項目名稱:yav,代碼行數:101,代碼來源:ArchivesController.php


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