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


PHP ObjectManager::getConnection方法代碼示例

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


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

示例1: execute

 /**
  * Change the property on the given node.
  *
  * @param NodeData $node
  * @return void
  */
 public function execute(NodeData $node)
 {
     foreach ($node->getNodeType()->getProperties() as $propertyName => $propertyConfiguration) {
         if (isset($propertyConfiguration['type']) && in_array(trim($propertyConfiguration['type']), $this->getHandledObjectTypes())) {
             if (!isset($nodeProperties)) {
                 $nodeRecordQuery = $this->entityManager->getConnection()->prepare('SELECT properties FROM typo3_typo3cr_domain_model_nodedata WHERE persistence_object_identifier=?');
                 $nodeRecordQuery->execute([$this->persistenceManager->getIdentifierByObject($node)]);
                 $nodeRecord = $nodeRecordQuery->fetch(\PDO::FETCH_ASSOC);
                 $nodeProperties = unserialize($nodeRecord['properties']);
             }
             if (!isset($nodeProperties[$propertyName]) || !is_object($nodeProperties[$propertyName])) {
                 continue;
             }
             /** @var Asset $assetObject */
             $assetObject = $nodeProperties[$propertyName];
             $nodeProperties[$propertyName] = null;
             $stream = $assetObject->getResource()->getStream();
             if ($stream === false) {
                 continue;
             }
             fclose($stream);
             $objectType = TypeHandling::getTypeForValue($assetObject);
             $objectIdentifier = ObjectAccess::getProperty($assetObject, 'Persistence_Object_Identifier', true);
             $nodeProperties[$propertyName] = array('__flow_object_type' => $objectType, '__identifier' => $objectIdentifier);
         }
     }
     if (isset($nodeProperties)) {
         $nodeUpdateQuery = $this->entityManager->getConnection()->prepare('UPDATE typo3_typo3cr_domain_model_nodedata SET properties=? WHERE persistence_object_identifier=?');
         $nodeUpdateQuery->execute([serialize($nodeProperties), $this->persistenceManager->getIdentifierByObject($node)]);
     }
 }
開發者ID:robertlemke,項目名稱:neos-development-collection,代碼行數:37,代碼來源:AssetTransformation.php

示例2: createTable

 public function createTable($name)
 {
     // remove table
     $pdo = $this->pdo->query('DROP TABLE IF EXISTS `' . $name . '`;');
     $pdo->execute();
     // create table
     $newSchema = new \Doctrine\DBAL\Schema\Schema();
     $newTable = $newSchema->createTable($name);
     $newTable->addColumn('container_id', 'integer');
     $newTable->addColumn('context_id', 'integer');
     $newTable->addColumn('module_id', 'integer');
     $newTable->addColumn('resource_id', 'integer')->setNotnull(false);
     $newTable->addColumn('by_resource_id', 'integer')->setNotnull(false);
     $newTable->addColumn('sequence', 'integer')->setNotnull(false);
     $newTable->addColumn('deleted', 'datetime')->setNotnull(false);
     $newTable->addColumn('display', 'boolean')->setNotnull(true);
     $newTable->addColumn('expire_temporary_date', 'datetime')->setNotnull(false);
     $newTable->addColumn('culture', 'string')->setLength(11);
     foreach ($this->eavColumns->getColumns() as $column) {
         if ($this->getTypeToColumn($column['column'])) {
             $newTable->addColumn($column['identifier'], $this->getTypeToColumn($column['column']))->setNotnull(false);
             $columnsToFill[] = $column['identifier'];
         }
     }
     $newTable->addForeignKeyConstraint($this->objectManager->getClassMetadata('BigfishEavBundle:Container')->getTablename(), array('container_id'), array('container_id'), array('onDelete' => 'CASCADE'));
     $newTable->addForeignKeyConstraint($this->objectManager->getClassMetadata('BigfishEavBundle:Module')->getTablename(), array('module_id'), array('module_id'), array('onDelete' => 'CASCADE'));
     $newTable->addForeignKeyConstraint($this->objectManager->getClassMetadata('BigfishContextBundle:Context')->getTablename(), array('context_id'), array('context_id'), array('onDelete' => 'CASCADE'));
     $newTable->addForeignKeyConstraint($this->objectManager->getClassMetadata('BigfishResourceBundle:Resource')->getTablename(), array('resource_id'), array('resource_id'), array('onDelete' => 'CASCADE'));
     $newTable->addForeignKeyConstraint($this->objectManager->getClassMetadata('BigfishResourceBundle:Resource')->getTablename(), array('by_resource_id'), array('resource_id'), array('onDelete' => 'CASCADE'));
     foreach ($newSchema->toSql($this->objectManager->getConnection()->getDatabasePlatform()) as $l) {
         $pdo = $this->pdo->prepare($l);
         $pdo->execute();
     }
 }
開發者ID:bigfishcmf,項目名稱:bigfishcmf,代碼行數:34,代碼來源:FlatternTable.php

示例3: getSql

 /**
  * @param DoctrineSqlFilter $sqlFilter
  * @param ClassMetadata $targetEntity Metadata object for the target entity to create the constraint for
  * @param string $targetTableAlias The target table alias used in the current query
  * @return string
  */
 public function getSql(DoctrineSqlFilter $sqlFilter, ClassMetadata $targetEntity, $targetTableAlias)
 {
     $quotedCollectionTitle = $this->entityManager->getConnection()->quote($this->collectionTitle);
     return $targetTableAlias . '.persistence_object_identifier IN (
         SELECT ' . $targetTableAlias . '_a.persistence_object_identifier
         FROM typo3_media_domain_model_asset AS ' . $targetTableAlias . '_a
         LEFT JOIN typo3_media_domain_model_assetcollection_assets_join ' . $targetTableAlias . '_acj ON ' . $targetTableAlias . '_a.persistence_object_identifier = ' . $targetTableAlias . '_acj.media_asset
         LEFT JOIN typo3_media_domain_model_assetcollection ' . $targetTableAlias . '_ac ON ' . $targetTableAlias . '_ac.persistence_object_identifier = ' . $targetTableAlias . '_acj.media_assetcollection
         WHERE ' . $targetTableAlias . '_ac.title = ' . $quotedCollectionTitle . ')';
 }
開發者ID:bwaidelich,項目名稱:Wwwision.AssetConstraints,代碼行數:16,代碼來源:AssetAssetCollectionConditionGenerator.php

示例4: load

 /**
  * Load data fixtures with the passed EntityManager
  *
  * @param \Doctrine\Common\Persistence\ObjectManager $manager
  */
 public function load(ObjectManager $manager)
 {
     $query = $manager->createQuery('SELECT COUNT(f) FROM \\Acme\\Bundle\\AppBundle\\Entity\\Fabric f');
     if (0 === $query->getSingleScalarResult()) {
         $stmt = $manager->getConnection()->prepare($this->getFabricsSql());
         $stmt->execute();
     }
     $query = $manager->createQuery('SELECT COUNT(c) FROM \\Acme\\Bundle\\AppBundle\\Entity\\Color c');
     if (0 === $query->getSingleScalarResult()) {
         $stmt = $manager->getConnection()->prepare($this->getColorSql());
         $stmt->execute();
     }
 }
開發者ID:abdeldayem,項目名稱:pim-community-dev,代碼行數:18,代碼來源:ReferenceDataLoader.php

示例5: collectResourcePointersCommand

 /**
  * Runs garbage collection for the ResourcePointers and their associated physical files
  * 
  * @return void
  */
 public function collectResourcePointersCommand()
 {
     $connection = $this->entityManager->getConnection();
     $path = FLOW_PATH_DATA . "Persistent/Resources/";
     // Find and delete all orphaned ResourcePointers
     $stmt = $connection->executeQuery('SELECT `hash` ' . 'FROM `typo3_flow_resource_resourcepointer` AS `rp` ' . 'LEFT OUTER JOIN `typo3_flow_resource_resource` AS `r` ON `r`.`resourcepointer` = `rp`.`hash` ' . 'WHERE `r`.`persistence_object_identifier` IS NULL ');
     foreach ($stmt->fetchAll(\PDO::FETCH_ASSOC) as $row) {
         $hash = $row["hash"];
         $this->outputLine("Found orphaned ResourcePointer: %s", array($hash));
         // Remove ResoursePointer from database
         $result = $connection->executeUpdate('DELETE FROM `typo3_flow_resource_resourcepointer` ' . 'WHERE `hash` = "' . $hash . '"');
         if ($result) {
             $this->outputLine("...deleted entity");
         } else {
             $this->outputLine("...COULD NOT DELETE ENTITY!");
         }
         // Remove physical file
         if (file_exists($path . $hash)) {
             if (unlink($path . $hash)) {
                 $this->outputLine("...deleted physical file");
             } else {
                 $this->outputLine("...COULD NOT DELETE PHYSICAL FILE!");
             }
         } else {
             $this->outputLine("...physical file already deleted");
         }
     }
     // Find and delete all orphaned physical files
     $files = scandir($path);
     $files = array_filter($files, function ($elem) {
         return preg_match('/^[0-9a-f]+$/', $elem);
     });
     // Create temporary table in memory and fill it with physical file hashes
     $connection->executeUpdate('CREATE TEMPORARY TABLE `etg24_cleanup_command_garbage_files` (`hash` CHAR(40)) ENGINE=MEMORY');
     if (!empty($files)) {
         $connection->executeUpdate('INSERT INTO `etg24_cleanup_command_garbage_files` (`hash`) VALUES ("' . implode('"), ("', $files) . '")');
     }
     $stmt = $connection->executeQuery('SELECT `f`.`hash` ' . 'FROM `etg24_cleanup_command_garbage_files` AS `f` ' . 'LEFT OUTER JOIN `typo3_flow_resource_resourcepointer` AS `rp` USING(`hash`) ' . 'WHERE `rp`.`hash` IS NULL ');
     foreach ($stmt->fetchAll(\PDO::FETCH_ASSOC) as $row) {
         $hash = $row["hash"];
         $this->outputLine("Found orphaned physical file: %s", array($hash));
         // Remove physical file
         if (unlink($path . $hash)) {
             $this->outputLine("...deleted physical file");
         } else {
             $this->outputLine("...COULD NOT DELETE PHYSICAL FILE!");
         }
     }
 }
開發者ID:etg24,項目名稱:cleanup,代碼行數:54,代碼來源:GarbageCommandController.php

示例6: getMaxIdentifierLength

 /**
  * Derive maximum identifier length from doctrine DBAL
  *
  * @return integer
  */
 protected function getMaxIdentifierLength()
 {
     if ($this->tableNameLengthLimit === null) {
         $this->tableNameLengthLimit = $this->entityManager->getConnection()->getDatabasePlatform()->getMaxIdentifierLength();
     }
     return $this->tableNameLengthLimit;
 }
開發者ID:robertlemke,項目名稱:flow-development-collection,代碼行數:12,代碼來源:FlowAnnotationDriver.php

示例7: load

 public function load(ObjectManager $manager)
 {
     $filename = "src/ESN/AdministrationBundle/DataFixtures/SQL/University.sql";
     $sql = file_get_contents($filename);
     $manager->getConnection()->exec($sql);
     $manager->flush();
 }
開發者ID:donatienthorez,項目名稱:sf_erp_esn,代碼行數:7,代碼來源:LoadUniversitiesData.php

示例8: truncate

 /**
  *
  * @param ObjectManager|EntityManager $manager            
  * @param
  *            $class
  * @return bool
  */
 public static function truncate(ObjectManager $manager, $class)
 {
     /**
      * @var $connection \Doctrine\DBAL\Connection
      */
     $connection = $manager->getConnection();
     /**
      * @var $cmd ClassMetadata
      */
     $cmd = $manager->getClassMetadata($class);
     $connection->beginTransaction();
     try {
         if ($connection->getDatabasePlatform()->getName() !== 'sqlite') {
             $connection->query('SET FOREIGN_KEY_CHECKS=0');
             $connection->executeUpdate($connection->getDatabasePlatform()->getTruncateTableSql($cmd->getTableName()));
             $connection->query('SET FOREIGN_KEY_CHECKS=1');
         } else {
             $connection->executeUpdate($connection->getDatabasePlatform()->getTruncateTableSql($cmd->getTableName()));
         }
         $connection->commit();
         return true;
     } catch (\Exception $e) {
         $connection->rollback();
         return false;
     }
 }
開發者ID:phpinheiros,項目名稱:infrastructure-doctrine,代碼行數:33,代碼來源:DoctrineHelper.php

示例9: load

 public function load(ObjectManager $manager)
 {
     $conn = $manager->getConnection();
     $stmt = $conn->prepare('select id from lots');
     $stmt->execute();
     $lotIds = [];
     while ($lotId = $stmt->fetchColumn()) {
         $lotIds[] = (int) $lotId;
     }
     $stmt = $conn->prepare('select id from users');
     $stmt->execute();
     $usrIds = [];
     while ($usrId = $stmt->fetchColumn()) {
         $usrIds[] = (int) $usrId;
     }
     for ($i = 0, $l = count($lotIds) * count($usrIds); $i < $l; $i++) {
         $lot = $manager->getRepository('BankrotSiteBundle:Lot')->find($lotIds[array_rand($lotIds)]);
         if ($lot->getBeginDate()) {
             if (0 === rand(0, 2)) {
                 $lw = new LotWatch();
                 $lw->setOwner($manager->getRepository('BankrotSiteBundle:User')->find($usrIds[array_rand($usrIds)]));
                 $lw->setLot($lot);
                 $lw->setPrice(rand(0, 1000000));
                 $lw->setCutOffPrice(rand(10, 5000));
                 $lw->setDay(new \DateTime('@' . rand($lot->getBeginDate()->getTimestamp(), $lot->getEndDate()->getTimestamp())));
                 $manager->persist($lw);
             }
         }
     }
     $manager->flush();
 }
開發者ID:bhdm,項目名稱:bankrot,代碼行數:31,代碼來源:LoadLotWatchData.php

示例10: load

 public function load(ObjectManager $manager)
 {
     $data = (include __DIR__ . '/../fixtures/user/users.php');
     $encoder = $this->container->get('security.password_encoder');
     $userManager = $this->container->get('medievistes.user_manager');
     $connection = $manager->getConnection();
     if ($connection->getDatabasePlatform()->getName() === 'mysql') {
         $connection->exec("ALTER TABLE {$manager->getClassMetadata(User::class)->getTableName()} AUTO_INCREMENT = 1;");
     }
     foreach ($data as $userData) {
         $class = $userManager->getUserClass($userData['type']);
         $user = (new $class())->setId((int) $userData['id'])->setUsername($userData['username'])->setEmail($userData['email'])->setPlainPassword($userData['plain_password'])->setSalt(md5(uniqid(null, true)))->enable((bool) $userData['is_active'])->setCreatedAt(new \DateTime($userData['created_at']))->setUpdatedAt(new \DateTime($userData['updated_at']));
         if (!empty($userData['activation_link_id'])) {
             $user->setActivationLink($this->getReference("activation-link-{$userData['activation_link_id']}"));
         }
         foreach ($userData['roles'] as $role) {
             $user->addRole($role);
         }
         foreach ($userData['troops'] as $troop) {
             $association = (new Association())->setUser($user)->setTroop($this->getReference("troop-{$troop['troop_id']}"))->setRole($this->getReference("troop-role-{$troop['role_id']}"));
             $user->addTroopAssociation($association);
             $manager->persist($association);
         }
         $password = $encoder->encodePassword($user, $userData['plain_password']);
         $user->setPassword($password);
         $manager->persist($user);
         $manager->flush();
         $this->addReference("user-{$user->getId()}", $user);
     }
     $manager->clear($class);
     $manager->clear(Association::class);
 }
開發者ID:Medievistes,項目名稱:application,代碼行數:32,代碼來源:LoadUserData.php

示例11: load

 /**
  * {@inheritDoc}
  */
 public function load(ObjectManager $manager)
 {
     $manager->getConnection()->executeQuery("SET foreign_key_checks = 0;");
     $pageEtat = new PageEtat();
     $pageEtat->setLibelle('brouillon');
     $manager->persist($pageEtat);
     $manager->flush();
     $pageEtat = new PageEtat();
     $pageEtat->setLibelle('A valider');
     $manager->persist($pageEtat);
     $manager->flush();
     $pageEtat = new PageEtat();
     $pageEtat->setLibelle('Validée');
     $manager->persist($pageEtat);
     $manager->flush();
     $manager->getConnection()->executeQuery("SET foreign_key_checks = 1;");
 }
開發者ID:Id2iDev,項目名稱:FrameworkSf2,代碼行數:20,代碼來源:Page.php

示例12: alisInkKlosterImportCommand

 /**
  */
 public function alisInkKlosterImportCommand()
 {
     /** @var DataImportController $importer */
     $importer = new DataImportController($this->logger, $this->settings);
     /** @var \Doctrine\DBAL\Connection $sqlConnection */
     $sqlConnection = $this->entityManager->getConnection();
     $sql = 'SET unique_checks = 0';
     $sqlConnection->executeUpdate($sql);
     $sql = 'SET foreign_key_checks = 0';
     $sqlConnection->executeUpdate($sql);
     $importer->delAccessKlosterTabAction();
     $importer->importAccessInkKlosterDataAction();
     $importer->importKlosterAction();
     $sql = 'SET foreign_key_checks = 1';
     $sqlConnection->executeUpdate($sql);
     $time = microtime(true) - $_SERVER["REQUEST_TIME_FLOAT"];
     $this->logger->log('Import completed in ' . $time . ' seconds.');
 }
開發者ID:subugoe,項目名稱:germaniasacra,代碼行數:20,代碼來源:GermaniaSacraCommandController.php

示例13: load

 /**
  * {@inheritdoc}
  */
 public function load(ObjectManager $manager)
 {
     /** @var \Doctrine\ORM\EntityManagerInterface $manager */
     $connection = $manager->getConnection();
     $date = (new \DateTime('-3 days'))->format('Y-m-d H:i:s');
     // we need to use bare sql
     // since the auth process is difficult to build when using the domain models
     $connection->exec("\nINSERT INTO SEN_Token (apiKey, tokenId) VALUES (PASSWORD(RAND()), 1);\nINSERT INTO SEN_User (credentials_username, credentials_password, profile_email, profile_realName, profile_registrationDate, profile_lastAction, profile_locked, profile_locale, tokenId)  VALUES ('Ma27', PASSWORD('test-password'), 'foo@bar.de', '', '" . $date . "', '" . $date . "', 0, 'en', 1);");
 }
開發者ID:thesoftwarefactoryuk,項目名稱:SenNetwork,代碼行數:12,代碼來源:LoadOutdatedApiKeyData.php

示例14: initializeConnection

    /**
     * Initializes the DBAL connection which is currently bound to the Doctrine Entity Manager
     *
     * @return void
     */
    protected function initializeConnection()
    {
        if (!$this->entityManager instanceof EntityManager) {
            $this->outputLine('This command only supports database connections provided by the Doctrine ORM Entity Manager.
				However, the current entity manager is an instance of %s.', array(get_class($this->entityManager)));
            $this->quit(1);
        }
        $this->dbalConnection = $this->entityManager->getConnection();
    }
開發者ID:robertlemke,項目名稱:neos-development-collection,代碼行數:14,代碼來源:MediaCommandController.php

示例15: __construct

 /**
  * @param ObjectManager    $objectManager
  * @param LanguageManager  $languageManager
  * @param ModuleRepository $moduleRepository
  * @param FlatternTable    $flatternTable
  */
 public function __construct(ObjectManager $objectManager, LanguageManager $languageManager, ModuleRepository $moduleRepository, FlatternTable $flatternTable)
 {
     $this->objectManager = $objectManager;
     $this->pdo = $objectManager->getConnection();
     $this->languageManager = $languageManager;
     $this->moduleRepository = $moduleRepository;
     $this->flatternTable = $flatternTable;
     return $this;
 }
開發者ID:bigfishcmf,項目名稱:bigfishcmf,代碼行數:15,代碼來源:FlatTableListener.php


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