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


PHP Model::getConnection方法代碼示例

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


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

示例1: import

 /**
  * Import an Eloquent
  *
  * @param Model $model
  * @param array $relations
  * @param int $batchSize
  * @param callable $callback
  * @internal param $type
  */
 public function import(Model $model, $relations = [], $batchSize = 750, callable $callback = null)
 {
     $batch = 0;
     $asQueryLoggind = $model->getConnection()->logging();
     $model->getConnection()->disableQueryLog();
     while (true) {
         // Increase the batch number
         $batch += 1;
         // Load records from the database
         $records = $model->newInstance()->with($relations)->skip($batchSize * ($batch - 1))->take($batchSize)->get();
         // Break out of the loop if we are out of records
         if (count($records) == 0) {
             break;
         }
         // Call the callback function to provide feedback on the import process
         if ($callback) {
             $callback($batch);
         }
         // Transform each record before sending it to Elasticsearch
         $data = [];
         foreach ($records as $record) {
             $data[] = ['index' => ['_id' => $record->getEsId()]];
             $data[] = $record->transform(!empty($relations));
         }
         // Bulk import the data to Elasticsearch
         $this->bulk($data);
     }
     if ($asQueryLoggind) {
         $model->getConnection()->enableQueryLog();
     }
 }
開發者ID:menthol,項目名稱:Flexible,代碼行數:40,代碼來源:Index.php

示例2: addMockConnection

 /**
  * Set mock connection.
  *
  * @param  \Illuminate\Database\Eloquent\Model  $model
  */
 protected function addMockConnection(Model $model)
 {
     $resolver = m::mock('\\Illuminate\\Database\\ConnectionResolverInterface');
     $model->setConnectionResolver($resolver);
     $resolver->shouldReceive('connection')->andReturn(m::mock('\\Illuminate\\Database\\Connection'));
     $model->getConnection()->shouldReceive('getQueryGrammar')->andReturn(m::mock('\\Illuminate\\Database\\Query\\Grammars\\Grammar'));
     $model->getConnection()->shouldReceive('getPostProcessor')->andReturn(m::mock('\\Illuminate\\Database\\Query\\Processors\\Processor'));
 }
開發者ID:DavidIWilson,項目名稱:site1,代碼行數:13,代碼來源:EloquentConnectionTrait.php

示例3: apply

 /**
  * {@inheritDoc}
  * @see \Illuminate\Database\Eloquent\ScopeInterface::apply()
  */
 public function apply(Builder $builder, Model $model)
 {
     /**
      * @var $model Model
      */
     $name = $model::getBootUseToTraitProperyName();
     $value = $model::${$name};
     $value = $model->getConnection()->getPdo()->quote($value);
     $builder->where($model->getQualifiedUseToFieldName(), new Expression($value));
     $this->addWithTrashed($builder);
 }
開發者ID:windqyoung,項目名稱:utils,代碼行數:15,代碼來源:UseToScope.php

示例4: schemaFields

 /**
  * Create fields for type.
  *
  * @return void
  */
 protected function schemaFields()
 {
     $table = $this->model->getTable();
     $schema = $this->model->getConnection()->getSchemaBuilder();
     $columns = collect($schema->getColumnListing($table));
     $columns->each(function ($column) use($table, $schema) {
         if (!$this->skipField($column)) {
             $this->generateField($column, $schema->getColumnType($table, $column));
         }
     });
 }
開發者ID:nuwave,項目名稱:laravel-graphql-relay,代碼行數:16,代碼來源:EloquentType.php

示例5: transaction

 /**
  * @param Closure $closure
  * @return mixed
  * @throws Exception
  */
 protected function transaction(Closure $closure)
 {
     $connection = $this->model->getConnection();
     $connection->beginTransaction();
     try {
         $result = $closure();
         $connection->commit();
         return $result;
     } catch (Exception $e) {
         $connection->rollBack();
         throw $e;
     }
 }
開發者ID:cloudcreativity,項目名稱:laravel-json-api,代碼行數:18,代碼來源:EloquentController.php

示例6: performTransaction

 public function performTransaction($amount, $sender_id, $recipient_id)
 {
     $connection = Eloquent::getConnection();
     try {
         $connection->getPdo()->beginTransaction();
         $sender = Balance::where('character_id', $sender_id)->first();
         $recipient = Balance::where('character_id', $recipient_id)->first();
         $sender->update(['amount' => $sender->amount - $amount]);
         $recipient->update(['amount' => $recipient->amount + $amount]);
         $connection->getPdo()->commit();
     } catch (\Exception $e) {
         $connection->getPdo()->rollback();
         return false;
     }
     return true;
 }
開發者ID:MichaelLeah,項目名稱:GalacticBank,代碼行數:16,代碼來源:Transaction.php

示例7: database

 protected function database(Model $model)
 {
     return $model->getConnection()->table($model->getTable());
 }
開發者ID:jaffle-be,項目名稱:framework,代碼行數:4,代碼來源:AdminTestCase.php

示例8: getPropertiesFromTable

 /**
  * Load the properties from the database table.
  *
  * @param \Illuminate\Database\Eloquent\Model $model
  */
 protected function getPropertiesFromTable($model)
 {
     $table = $model->getTable();
     $schema = $model->getConnection()->getDoctrineSchemaManager($table);
     $schema->getDatabasePlatform()->registerDoctrineTypeMapping('enum', 'string');
     $columns = $schema->listTableColumns($table);
     if ($columns) {
         foreach ($columns as $column) {
             $name = $column->getName();
             $type = $column->getType()->getName();
             switch ($type) {
                 case 'string':
                 case 'text':
                 case 'date':
                 case 'time':
                 case 'guid':
                     $type = 'string';
                     break;
                 case 'integer':
                 case 'bigint':
                 case 'smallint':
                     $type = 'integer';
                     break;
                 case 'decimal':
                 case 'float':
                     $type = 'float';
                     break;
                 case 'boolean':
                     $type = 'boolean';
                     break;
                 case 'datetimetz':
                     //String or DateTime, depending on $dates
                 //String or DateTime, depending on $dates
                 case 'datetime':
                     $type = '\\Carbon\\Carbon';
                     break;
                 default:
                     $type = 'mixed';
                     break;
             }
             $this->setProperty($name, $type, true, true);
         }
     }
 }
開發者ID:ngogiangthanh,項目名稱:code-nien-luan-ktpm-k36,代碼行數:49,代碼來源:ModelsCommand.php

示例9: getTableColumns

 private function getTableColumns(Model $model)
 {
     return $model->getConnection()->getSchemaBuilder()->getColumnListing($model->getTable());
 }
開發者ID:roshangara,項目名稱:datatables-handler,代碼行數:4,代碼來源:DatatablesHandler.php

示例10: __construct

 /**
  * @param \Illuminate\Database\Eloquent\Model $model
  */
 public function __construct(Model $model)
 {
     $this->model = $model;
     $this->db = $model->getConnection();
 }
開發者ID:legalweb,項目名稱:php-statistics-helper,代碼行數:8,代碼來源:AbstractEloquentStatisticsProvider.php

示例11: delete

 /**
  * Delete entity values.
  *
  * @throws \InvalidArgumentException
  */
 public function delete()
 {
     if (!in_array(SoftDeletes::class, class_uses_recursive(get_class($this->entity)), true) || $this->entity->forceDeleting) {
         $instance = new Value();
         $connection = $this->entity->getConnection();
         $connection->table($instance->getTable())->where('entity_id', $this->entity->getKey())->whereIn('property_id', $this->properties->pluck('id'))->delete();
     }
 }
開發者ID:dkulyk,項目名稱:eloquent-extra,代碼行數:13,代碼來源:Factory.php

示例12: getConnection

 /**
  * {@inheritdoc}
  */
 protected function getConnection()
 {
     return $this->model->getConnection();
 }
開發者ID:viniciusferreira,項目名稱:laravel-repository,代碼行數:7,代碼來源:EloquentRepository.php

示例13: getNullable

 /**
  * Check if column is nullable.
  *
  * @param  \Illuminate\Database\Eloquent\Model  $model
  * @param  string  $column
  * @return bool
  */
 public function getNullable($model, $column)
 {
     $schema = $model->getConnection()->getDoctrineSchemaManager($model->getTable());
     $columns = $schema->listTableColumns($model->getTable());
     return isset($columns[$column]) ? !$columns[$column]->getNotnull() : false;
 }
開發者ID:ThisVessel,項目名稱:Caravel,代碼行數:13,代碼來源:DbalHelpers.php

示例14: getPropertiesFromTable

 /**
  * Load the properties from the database table.
  *
  * @param \Illuminate\Database\Eloquent\Model $model
  */
 protected function getPropertiesFromTable($model)
 {
     $table = $model->getConnection()->getTablePrefix() . $model->getTable();
     $schema = $model->getConnection()->getDoctrineSchemaManager($table);
     $databasePlatform = $schema->getDatabasePlatform();
     $databasePlatform->registerDoctrineTypeMapping('enum', 'string');
     $platformName = $databasePlatform->getName();
     $customTypes = $this->laravel['config']->get("ide-helper.custom_db_types.{$platformName}", array());
     foreach ($customTypes as $yourTypeName => $doctrineTypeName) {
         $databasePlatform->registerDoctrineTypeMapping($yourTypeName, $doctrineTypeName);
     }
     $database = null;
     if (strpos($table, '.')) {
         list($database, $table) = explode('.', $table);
     }
     $columns = $schema->listTableColumns($table, $database);
     if ($columns) {
         foreach ($columns as $column) {
             $name = $column->getName();
             if (in_array($name, $model->getDates())) {
                 $type = 'datetime';
             } else {
                 $type = $column->getType()->getName();
             }
             if (!($model->incrementing && $model->getKeyName() === $name) && $name !== $model::CREATED_AT && $name !== $model::UPDATED_AT) {
                 if (!method_exists($model, 'getDeletedAtColumn') || method_exists($model, 'getDeletedAtColumn') && $name !== $model->getDeletedAtColumn()) {
                     $this->setProperty($name, $type);
                 }
             }
         }
     }
 }
開發者ID:mpociot,項目名稱:laravel-test-factory-helper,代碼行數:37,代碼來源:GenerateCommand.php

示例15: getPropertiesFromTable

 /**
  * Load the properties from the database table.
  *
  * @param \Illuminate\Database\Eloquent\Model $model
  */
 protected function getPropertiesFromTable($model)
 {
     $table = $model->getConnection()->getTablePrefix() . $model->getTable();
     $schema = $model->getConnection()->getDoctrineSchemaManager($table);
     $schema->getDatabasePlatform()->registerDoctrineTypeMapping('enum', 'string');
     $columns = $schema->listTableColumns($table);
     if ($columns) {
         foreach ($columns as $column) {
             $name = $column->getName();
             if (in_array($name, $model->getDates())) {
                 $type = '\\Carbon\\Carbon';
             } else {
                 $type = $column->getType()->getName();
                 switch ($type) {
                     case 'string':
                     case 'text':
                     case 'date':
                     case 'time':
                     case 'guid':
                     case 'datetimetz':
                     case 'datetime':
                         $type = 'string';
                         break;
                     case 'integer':
                     case 'bigint':
                     case 'smallint':
                         $type = 'integer';
                         break;
                     case 'decimal':
                     case 'float':
                         $type = 'float';
                         break;
                     case 'boolean':
                         $type = 'boolean';
                         break;
                     default:
                         $type = 'mixed';
                         break;
                 }
             }
             $this->setProperty($name, $type, true, true);
             $this->setMethod(Str::camel("where_" . $name), '\\Illuminate\\Database\\Query\\Builder|\\' . get_class($model), array('$value'));
         }
     }
 }
開發者ID:erpio,項目名稱:Reportula,代碼行數:50,代碼來源:ModelsCommand.php


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