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


PHP Association::primaryKey方法代碼示例

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


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

示例1: _manyToOneAssociatedRecords

 /**
  * Method that retrieves many to one associated records
  * @param  \Cake\ORM\Table       $table       Table object
  * @param  \Cake\ORM\Association $association Association object
  * @return array                              associated records
  */
 protected function _manyToOneAssociatedRecords(\Cake\ORM\Table $table, \Cake\ORM\Association $association)
 {
     $tableName = $table->table();
     $primaryKey = $table->primaryKey();
     $assocTableName = $association->table();
     $assocPrimaryKey = $association->primaryKey();
     $assocForeignKey = $association->foreignKey();
     $recordId = $this->request->params['pass'][0];
     $displayField = $association->displayField();
     $connection = ConnectionManager::get('default');
     $records = $connection->execute('SELECT ' . $assocTableName . '.' . $displayField . ' FROM ' . $tableName . ' LEFT JOIN ' . $assocTableName . ' ON ' . $tableName . '.' . $assocForeignKey . ' = ' . $assocTableName . '.' . $assocPrimaryKey . ' WHERE ' . $tableName . '.' . $primaryKey . ' = :id LIMIT 1', ['id' => $recordId])->fetchAll('assoc');
     // store associated table records
     $result = $records[0][$displayField];
     return $result;
 }
開發者ID:QoboLtd,項目名稱:cakephp-csv-views,代碼行數:21,代碼來源:CsvViewComponent.php

示例2: _manyToOneAssociatedRecords

 /**
  * Method that retrieves many to one associated records.
  *
  * @param  \Cake\ORM\Association $association Association object
  * @param \Cake\Network\Request $request passed
  * @return array associated records
  */
 protected function _manyToOneAssociatedRecords(Association $association, Request $request)
 {
     $result = [];
     $tableName = $this->_tableInstance->table();
     $primaryKey = $this->_tableInstance->primaryKey();
     $assocTableName = $association->table();
     $assocPrimaryKey = $association->primaryKey();
     $assocForeignKey = $association->foreignKey();
     $recordId = $request->params['pass'][0];
     $displayField = $association->displayField();
     /*
      * skip inverse relationship
      *
      * @todo find better way to handle it
      */
     if ($tableName === $assocTableName) {
         return $result;
     }
     $connection = ConnectionManager::get('default');
     // NOTE: This will break if $assocTableName has no primary key or has a combined primary key
     $records = $connection->execute('SELECT ' . $assocTableName . '.' . $assocPrimaryKey . ' FROM ' . $tableName . ' LEFT JOIN ' . $assocTableName . ' ON ' . $tableName . '.' . $assocForeignKey . ' = ' . $assocTableName . '.' . $assocPrimaryKey . ' WHERE ' . $tableName . '.' . $primaryKey . ' = :id LIMIT 1', ['id' => $recordId])->fetchAll('assoc');
     // store associated table records, make sure associated record still exists.
     if (!empty($records[0][$assocPrimaryKey]) && $association->exists([$assocPrimaryKey => $records[0][$assocPrimaryKey]])) {
         //$result = $association->get($records[0][$assocPrimaryKey])->{$displayField};
         $records = $association->get($records[0][$assocPrimaryKey]);
     } else {
         $records = null;
     }
     try {
         $csvFields = $this->_getAssociationCsvFields($association, static::ASSOC_FIELDS_ACTION);
     } catch (\Exception $e) {
         $csvFields = [];
     }
     // get associated index View csv fields
     $fields = array_unique(array_merge([$association->displayField()], $csvFields));
     // store association name
     $result['assoc_name'] = $association->name();
     // store associated table name
     $result['table_name'] = $association->table();
     // store associated table class name
     $result['class_name'] = $association->className();
     // store associated table display field
     $result['display_field'] = $association->displayField();
     // store associated table primary key
     $result['primary_key'] = $association->primaryKey();
     // store associated table foreign key
     $result['foreign_key'] = Inflector::singularize($assocTableName) . '_' . $association->primaryKey();
     // store associated table fields
     $result['fields'] = $fields;
     // store associated table records
     $result['records'] = $records;
     return $result;
 }
開發者ID:QoboLtd,項目名稱:cakephp-csv-migrations,代碼行數:60,代碼來源:ViewViewTabsListener.php


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