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


PHP Type::getType方法代碼示例

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


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

示例1: hydrateEntity

 public function hydrateEntity($entity, array $values)
 {
     $classMetadata = $this->em->getClassMetadata(get_class($entity));
     foreach ($values as $fieldName => $value) {
         if ($classMetadata->hasField($fieldName)) {
             $fieldMappping = $classMetadata->getFieldMapping($fieldName);
             if (null === $fieldMappping) {
                 throw new HydrationException($fieldName);
             }
             $type = Type::getType($classMetadata->fieldMappings[$fieldName]['type']);
             $value = $type->convertToPHPValue($value, $this->em->getConnection()->getDatabasePlatform());
             $classMetadata->setFieldValue($entity, $fieldName, $value);
         } elseif (isset($classMetadata->associationMappings[$fieldName])) {
             $fieldMapping = $classMetadata->associationMappings[$fieldName];
             if (ClassMetadataInfo::MANY_TO_MANY === $fieldMapping['type']) {
                 // expecting an array of ids in $value
                 if (1 === count($fieldMapping['relationToTargetKeyColumns'])) {
                     $columnName = array_pop($fieldMapping['relationToTargetKeyColumns']);
                     $otherSideMapping = $this->em->getClassMetadata($fieldMapping['targetEntity']);
                     $value = $this->em->getRepository($fieldMapping['targetEntity'])->findBy(array($otherSideMapping->fieldNames[$columnName] => $value));
                 }
                 $classMetadata->setFieldValue($entity, $fieldName, $value);
             } elseif (ClassMetadataInfo::MANY_TO_ONE === $fieldMapping['type']) {
                 // expecting an array of ids in $value
                 $value = $this->em->getRepository($fieldMapping['targetEntity'])->find($value);
                 $classMetadata->setFieldValue($entity, $fieldName, $value);
             }
         } else {
             throw new HydrationException($fieldName);
         }
     }
 }
開發者ID:gobjila,項目名稱:BackBee,代碼行數:32,代碼來源:RestHydrator.php

示例2: getFieldByTagVaule

 private function getFieldByTagVaule($tag_value)
 {
     $value_and_params = $this->parseTagValueAndParameters($tag_value);
     $type = trim($value_and_params['value']);
     $params = $value_and_params['parameters'];
     return new \Hitar\FieldType($params, \Doctrine\DBAL\Types\Type::getType($type));
 }
開發者ID:kasonyang,項目名稱:hitar,代碼行數:7,代碼來源:OrmAnnotation.php

示例3: table_should_contain_binary_uuid_column

 /**
  * @test
  */
 public function table_should_contain_binary_uuid_column()
 {
     $uuidColumn = $this->table->getColumn('uuid');
     $this->assertEquals(16, $uuidColumn->getLength());
     $this->assertEquals(Type::getType(Type::BINARY), $uuidColumn->getType());
     $this->assertTrue($uuidColumn->getFixed());
 }
開發者ID:2dotstwice,項目名稱:broadway,代碼行數:10,代碼來源:BinaryDBALEventStoreTest.php

示例4: convertResultsInternal

 protected function convertResultsInternal($results, AbstractPlatform $platform, CaseSensor $sensor)
 {
     if (is_array($results)) {
         $results = current($results);
     }
     return Type::getType($this->type)->convertToPHPValue($results, $platform);
 }
開發者ID:ritalin,項目名稱:omelet,代碼行數:7,代碼來源:BuiltinDomain.php

示例5: walkSelectStatement

 /**
  * Walks down a SelectStatement AST node, modifying it to retrieve DISTINCT ids
  * of the root Entity
  *
  * @param SelectStatement $AST
  * @return void
  */
 public function walkSelectStatement(SelectStatement $AST)
 {
     $parent = null;
     $parentName = null;
     $selectExpressions = array();
     foreach ($this->_getQueryComponents() as $dqlAlias => $qComp) {
         // preserve mixed data in query for ordering
         if (isset($qComp['resultVariable'])) {
             $selectExpressions[] = new SelectExpression($qComp['resultVariable'], $dqlAlias);
             continue;
         }
         if ($qComp['parent'] === null && $qComp['nestingLevel'] == 0) {
             $parent = $qComp;
             $parentName = $dqlAlias;
             continue;
         }
     }
     $identifier = $parent['metadata']->getSingleIdentifierFieldName();
     $this->_getQuery()->setHint(self::IDENTIFIER_TYPE, Type::getType($parent['metadata']->getTypeOfField($identifier)));
     $pathExpression = new PathExpression(PathExpression::TYPE_STATE_FIELD | PathExpression::TYPE_SINGLE_VALUED_ASSOCIATION, $parentName, $identifier);
     $pathExpression->type = PathExpression::TYPE_STATE_FIELD;
     array_unshift($selectExpressions, new SelectExpression($pathExpression, '_dctrn_id'));
     $AST->selectClause->selectExpressions = $selectExpressions;
     if (isset($AST->orderByClause)) {
         foreach ($AST->orderByClause->orderByItems as $item) {
             if ($item->expression instanceof PathExpression) {
                 $pathExpression = new PathExpression(PathExpression::TYPE_STATE_FIELD | PathExpression::TYPE_SINGLE_VALUED_ASSOCIATION, $item->expression->identificationVariable, $item->expression->field);
                 $pathExpression->type = PathExpression::TYPE_STATE_FIELD;
                 $AST->selectClause->selectExpressions[] = new SelectExpression($pathExpression, '_dctrn_ord' . $this->_aliasCounter++);
             }
         }
     }
     $AST->selectClause->isDistinct = true;
 }
開發者ID:davidbui2,項目名稱:doctrine2,代碼行數:41,代碼來源:LimitSubqueryWalker.php

示例6: up

 /**
  * @inheritdoc
  */
 public function up(Schema $schema, QueryBag $queries)
 {
     $table = $schema->getTable('orocrm_sales_opportunity');
     $table->getColumn('probability')->setType(Type::getType('percent'));
     $table->getColumn('budget_amount')->setType(Type::getType('money'));
     $table->getColumn('close_revenue')->setType(Type::getType('money'));
 }
開發者ID:antrampa,項目名稱:crm,代碼行數:10,代碼來源:OroCRMSalesBundle.php

示例7: up

 /**
  * {@inheritdoc}
  */
 public function up(Schema $schema, QueryBag $queries)
 {
     $table = $schema->getTable('orocrm_magento_cart');
     $table->getColumn('items_qty')->setType(Type::getType('float'));
     $table = $schema->getTable('orocrm_magento_order_items');
     $table->getColumn('qty')->setType(Type::getType('float'));
 }
開發者ID:antrampa,項目名稱:crm,代碼行數:10,代碼來源:OroCRMMagentoBundle.php

示例8: createService

 /**
  * Create service
  *
  * @param  ServiceLocatorInterface $validators
  * @return mixed
  */
 public function createService(ServiceLocatorInterface $validators)
 {
     if (isset($this->options['enum'])) {
         $this->options['enum'] = DoctrineType::getType($this->options['enum']);
     }
     return new EnumValidator($this->options);
 }
開發者ID:bvoronov,項目名稱:zb-utils,代碼行數:13,代碼來源:EnumValidatorFactory.php

示例9: testAlterTableSql

 public function testAlterTableSql()
 {
     $changes = array('name' => 'userlist', 'add' => array('quota' => array('type' => Type::getType('integer'))));
     $sql = $this->_platform->getAlterTableSql('mytable', $changes);
     $this->assertEquals('ALTER TABLE mytable ADD quota INT DEFAULT NULL', $sql[0]);
     $this->assertEquals('ALTER TABLE mytable RENAME TO userlist', $sql[1]);
 }
開發者ID:jackbravo,項目名稱:doctrine,代碼行數:7,代碼來源:PostgreSqlPlatformTest.php

示例10: I_can_register_all_codes_at_once

 /**
  * @test
  */
 public function I_can_register_all_codes_at_once()
 {
     $typeName = $this->getExpectedTypeName();
     self::assertFalse(Type::hasType($typeName), "Type of name '{$typeName}' should not be registered yet");
     /** @var ScalarEnumType $typeClass */
     $typeClass = $this->getTypeClass();
     foreach ($this->getRelatedCodeClasses() as $relatedCodeClass) {
         self::assertFalse($typeClass::hasSubTypeEnum($relatedCodeClass), "Sub-type enum of a class '{$relatedCodeClass}' should not be registered yet");
     }
     $typeClass::registerSelf();
     self::assertTrue(Type::hasType($typeName), "Type of name '{$typeName}' is not registered");
     $testedType = Type::getType($typeName);
     $platform = $this->createPlatform();
     foreach ($this->getRelatedCodeClasses() as $relatedCodeClass) {
         self::assertTrue($typeClass::hasSubTypeEnum($relatedCodeClass), "Sub-type enum of a class '{$relatedCodeClass}' is not registered");
         foreach ($relatedCodeClass::getPossibleValues() as $possibleValue) {
             $asPhp = $testedType->convertToPHPValue($relatedCodeClass . '::' . $possibleValue, $platform);
             self::assertInstanceOf($relatedCodeClass, $asPhp);
             /** @var AbstractCode $asPhp */
             self::assertSame($possibleValue, $asPhp->getValue());
         }
     }
     $typeClass::registerSelf();
     // test if can call registering repeatedly
 }
開發者ID:jaroslavtyc,項目名稱:drd-plus-codes,代碼行數:28,代碼來源:AbstractCodeTypeTest.php

示例11: walkSelectStatement

 /**
  * Walks down a SelectStatement AST node, modifying it to retrieve DISTINCT ids
  * of the root Entity.
  *
  * @param SelectStatement $AST
  *
  * @return void
  *
  * @throws \RuntimeException
  */
 public function walkSelectStatement(SelectStatement $AST)
 {
     $queryComponents = $this->_getQueryComponents();
     // Get the root entity and alias from the AST fromClause
     $from = $AST->fromClause->identificationVariableDeclarations;
     $fromRoot = reset($from);
     $rootAlias = $fromRoot->rangeVariableDeclaration->aliasIdentificationVariable;
     $rootClass = $queryComponents[$rootAlias]['metadata'];
     $selectExpressions = array();
     foreach ($queryComponents as $dqlAlias => $qComp) {
         // Preserve mixed data in query for ordering.
         if (isset($qComp['resultVariable'])) {
             $selectExpressions[] = new SelectExpression($qComp['resultVariable'], $dqlAlias);
             continue;
         }
     }
     $identifier = $rootClass->getSingleIdentifierFieldName();
     if (isset($rootClass->associationMappings[$identifier])) {
         throw new \RuntimeException("Paginating an entity with foreign key as identifier only works when using the Output Walkers. Call Paginator#setUseOutputWalkers(true) before iterating the paginator.");
     }
     $this->_getQuery()->setHint(self::IDENTIFIER_TYPE, Type::getType($rootClass->getTypeOfField($identifier)));
     $pathExpression = new PathExpression(PathExpression::TYPE_STATE_FIELD | PathExpression::TYPE_SINGLE_VALUED_ASSOCIATION, $rootAlias, $identifier);
     $pathExpression->type = PathExpression::TYPE_STATE_FIELD;
     array_unshift($selectExpressions, new SelectExpression($pathExpression, '_dctrn_id'));
     $AST->selectClause->selectExpressions = $selectExpressions;
     if (isset($AST->orderByClause)) {
         foreach ($AST->orderByClause->orderByItems as $item) {
             if (!$item->expression instanceof PathExpression) {
                 continue;
             }
             $AST->selectClause->selectExpressions[] = new SelectExpression($this->createSelectExpressionItem($item->expression), '_dctrn_ord' . $this->_aliasCounter++);
         }
     }
     $AST->selectClause->isDistinct = true;
 }
開發者ID:dracony,項目名稱:forked-php-orm-benchmark,代碼行數:45,代碼來源:LimitSubqueryWalker.php

示例12: convertValue

 /**
  * {@inheritdoc}
  */
 public function convertValue($value, array $options, ConversionHints $hints)
 {
     if (2 === $hints->conversionStrategy || 3 === $hints->conversionStrategy) {
         return DBALType::getType('date')->convertToDatabaseValue($value, $hints->connection->getDatabasePlatform());
     }
     return (int) $value;
 }
開發者ID:rollerworks,項目名稱:search-doctrine-dbal,代碼行數:10,代碼來源:AgeDateConversion.php

示例13: testCreateTemporaryTableNotAutoCommitTransaction

 /**
  * @group DDC-1337
  * @return void
  */
 public function testCreateTemporaryTableNotAutoCommitTransaction()
 {
     if ($this->_conn->getDatabasePlatform()->getName() == 'sqlanywhere' || $this->_conn->getDatabasePlatform()->getName() == 'oracle') {
         $this->markTestSkipped("Test does not work on Oracle and SQL Anywhere.");
     }
     $platform = $this->_conn->getDatabasePlatform();
     $columnDefinitions = array("id" => array("type" => Type::getType("integer"), "notnull" => true));
     $tempTable = $platform->getTemporaryTableName("my_temporary");
     $createTempTableSQL = $platform->getCreateTemporaryTableSnippetSQL() . ' ' . $tempTable . ' (' . $platform->getColumnDeclarationListSQL($columnDefinitions) . ')';
     $table = new Table("nontemporary");
     $table->addColumn("id", "integer");
     $table->setPrimaryKey(array('id'));
     foreach ($platform->getCreateTableSQL($table) as $sql) {
         $this->_conn->executeQuery($sql);
     }
     $this->_conn->beginTransaction();
     $this->_conn->insert("nontemporary", array("id" => 1));
     $this->_conn->exec($createTempTableSQL);
     $this->_conn->insert("nontemporary", array("id" => 2));
     $this->_conn->rollback();
     try {
         $this->_conn->exec($platform->getDropTemporaryTableSQL($tempTable));
     } catch (\Exception $e) {
     }
     $rows = $this->_conn->fetchAll('SELECT * FROM nontemporary');
     $this->assertEquals(array(), $rows, "In an event of an error this result has one row, because of an implicit commit.");
 }
開發者ID:selimcr,項目名稱:servigases,代碼行數:31,代碼來源:TemporaryTableTest.php

示例14: test_importSchemaArray

 public function test_importSchemaArray()
 {
     $instance = new Xoops\Core\Database\Schema\ExportVisitor();
     $table = new Doctrine\DBAL\Schema\Table('system_group');
     $type = Type::getType(Type::INTEGER);
     $col_name = 'groupid';
     $column = new Doctrine\DBAL\Schema\Column($col_name, $type);
     $instance->acceptColumn($table, $column);
     $columns = array('groupid');
     $fk_table = 'system_permission';
     $fk_name = 'fk_name';
     $fk_options = array('o' => 'o1');
     $fk_columns = array('system_permission');
     $fk_constraint = new Doctrine\DBAL\Schema\ForeignKeyConstraint($columns, $fk_table, $fk_columns, $fk_name, $fk_options);
     $instance->acceptForeignKey($table, $fk_constraint);
     $name = 'index_name';
     $columns = array('name', 'description');
     $unique = true;
     $primary = true;
     $index = new Doctrine\DBAL\Schema\Index($name, $columns, $unique, $primary);
     $instance->acceptIndex($table, $index);
     $name = 'sequence_name';
     $alloc_size = 10;
     $initial_value = 11;
     $sequence = new Doctrine\DBAL\Schema\Sequence($name, $alloc_size, $initial_value);
     $instance->acceptSequence($sequence);
     $schema = $instance->getSchemaArray();
     $import = new $this->myClass();
     $value = $import->importSchemaArray($schema);
     $this->assertInstanceOf('Doctrine\\DBAL\\Schema\\Schema', $value);
 }
開發者ID:ming-hai,項目名稱:XoopsCore,代碼行數:31,代碼來源:ImportSchemaTest.php

示例15: changePrimaryKeyType

 /**
  * @param Schema   $schema
  * @param QueryBag $queries
  * @param string   $tableName
  * @param string   $columnName
  * @param string   $type
  *
  * @throws \Exception
  */
 public function changePrimaryKeyType(Schema $schema, QueryBag $queries, $tableName, $columnName, $type)
 {
     $targetColumn = $schema->getTable($tableName)->getColumn($columnName);
     $type = Type::getType($type);
     if ($targetColumn->getType() === $type) {
         return;
     }
     /** @var ForeignKeyConstraint[] $foreignKeys */
     $foreignKeys = [];
     foreach ($schema->getTables() as $table) {
         /** @var ForeignKeyConstraint[] $tableForeignKeys */
         $tableForeignKeys = array_filter($table->getForeignKeys(), function (ForeignKeyConstraint $tableForeignKey) use($tableName, $columnName) {
             if ($tableForeignKey->getForeignTableName() !== $tableName) {
                 return false;
             }
             return $tableForeignKey->getForeignColumns() === [$columnName];
         });
         foreach ($tableForeignKeys as $tableForeignKey) {
             $foreignKeys[$tableForeignKey->getName()] = $tableForeignKey;
             $foreignKeyTableName = $tableForeignKey->getLocalTable()->getName();
             $foreignKeyColumnNames = $tableForeignKey->getLocalColumns();
             $queries->addPreQuery($this->platform->getDropForeignKeySQL($tableForeignKey, $foreignKeyTableName));
             $column = $schema->getTable($foreignKeyTableName)->getColumn(reset($foreignKeyColumnNames));
             if ($column instanceof ExtendColumn) {
                 $column->disableExtendOptions()->setType($type)->enableExtendOptions();
             } else {
                 $column->setType($type);
             }
         }
     }
     $targetColumn->setType($type);
     foreach ($foreignKeys as $foreignKey) {
         $queries->addPostQuery($this->platform->getCreateForeignKeySQL($foreignKey, $foreignKey->getLocalTable()));
     }
 }
開發者ID:Maksold,項目名稱:platform,代碼行數:44,代碼來源:ChangeTypeExtension.php


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