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


PHP DatabaseManager::getTablePrefix方法代碼示例

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


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

示例1: build

 /**
  * Builds the necessary fields on the object
  *
  * @return void
  */
 public function build()
 {
     $model = $this->config->getDataModel();
     $options = $this->suppliedOptions;
     $this->tablePrefix = $this->db->getTablePrefix();
     //set some options-based defaults
     $options['title'] = $this->validator->arrayGet($options, 'title', $options['column_name']);
     $options['sort_field'] = $this->validator->arrayGet($options, 'sort_field', $options['column_name']);
     //if the supplied item is an accessor, make this unsortable for the moment
     if (method_exists($model, camel_case('get_' . $options['column_name'] . '_attribute')) && $options['column_name'] === $options['sort_field']) {
         $options['sortable'] = false;
     }
     //however, if this is not a relation and the select option was supplied, str_replace the select option and make it sortable again
     if ($select = $this->validator->arrayGet($options, 'select')) {
         $options['select'] = str_replace('(:table)', $this->tablePrefix . $model->getTable(), $select);
     }
     //now we do some final organization to categorize these columns (useful later in the sorting)
     if (method_exists($model, camel_case('get_' . $options['column_name'] . '_attribute')) || $select) {
         $options['is_computed'] = true;
     } else {
         $options['is_included'] = true;
     }
     //run the visible property closure if supplied
     $visible = $this->validator->arrayGet($options, 'visible');
     if (is_callable($visible)) {
         $options['visible'] = $visible($this->config->getDataModel()) ? true : false;
     }
     $this->suppliedOptions = $options;
 }
開發者ID:dmitriyuch,項目名稱:Laravel-Administrator,代碼行數:34,代碼來源:Column.php

示例2: updateRelationshipOptions

 /**
  * Given a model, field, type (filter or edit), and constraints (either int or array), returns an array of options
  *
  * @param string	$field
  * @param string	$type			//either 'filter' or 'edit'
  * @param array		$constraints	//an array of ids of the other model's items
  * @param array		$selectedItems	//an array of ids that are currently selected
  * @param string	$term			//the search term
  *
  * @return array
  */
 public function updateRelationshipOptions($field, $type, $constraints, $selectedItems, $term = null)
 {
     //first get the related model and fetch the field's options
     $model = $this->config->getDataModel();
     $relatedModel = $model->{$field}()->getRelated();
     $relatedTable = $relatedModel->getTable();
     $relatedKeyName = $relatedModel->getKeyName();
     $relatedKeyTable = $relatedTable . '.' . $relatedKeyName;
     $fieldObject = $this->getFieldObjectByName($field, $type);
     //if we can't find the field, return an empty array
     if (!$fieldObject) {
         return array();
     }
     //make sure we're grouping by the model's id
     $query = $relatedModel->newQuery();
     //set up the selects
     $query->select(array($this->db->raw($this->db->getTablePrefix() . $relatedTable . '.*')));
     //format the selected items into an array
     $selectedItems = $this->formatSelectedItems($selectedItems);
     //if this is an autocomplete field, check if there is a search term. If not, just return the selected items
     if ($fieldObject->getOption('autocomplete') && !$term) {
         if (sizeof($selectedItems)) {
             $this->filterQueryBySelectedItems($query, $selectedItems, $fieldObject, $relatedKeyTable);
             return $this->formatSelectOptions($fieldObject, $query->get());
         } else {
             return array();
         }
     }
     //applies constraints if there are any
     $this->applyConstraints($constraints, $query, $fieldObject);
     //if there is a search term, limit the result set by that term
     $this->filterBySearchTerm($term, $query, $fieldObject, $selectedItems, $relatedKeyTable);
     //perform any user-supplied options filter
     $filter = $fieldObject->getOption('options_filter');
     $filter($query);
     //finally we can return the options
     return $this->formatSelectOptions($fieldObject, $query->get());
 }
開發者ID:dmitriyuch,項目名稱:Laravel-Administrator,代碼行數:49,代碼來源:Factory.php


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