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


PHP Propel::getConnection方法代碼示例

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


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

示例1: updateOrCreateLinkAction

 public function updateOrCreateLinkAction($id)
 {
     // Check current user authorization
     if (null !== ($response = $this->checkAuth(AdminResources::MODULE, DealerTeam::getModuleCode(), AccessManager::CREATE))) {
         return $response;
     }
     $retour = [];
     $code = 200;
     $con = Propel::getConnection();
     $con->beginTransaction();
     try {
         $data = ['id' => $id];
         $tempOption = $this->getRequest()->request->get("option_id");
         $dafyDealer = [];
         foreach ($tempOption as $option) {
             $data["dealer_option_id"] = $option;
             $temp = $this->getService()->createFromArray($data);
             if ($temp) {
                 $dafyDealer[] = $temp->toArray();
             }
         }
         $con->commit();
         $retour["data"] = $dafyDealer;
     } catch (\Exception $e) {
         $con->rollBack();
         // Any other error
         Tlog::getInstance()->addError($e->getMessage());
         $code = $e->getCode();
         if ($code == 0) {
             $code = 500;
         }
         $retour["message"] = $e->getMessage();
     }
     return JsonResponse::create($retour, $code);
 }
開發者ID:thelia-modules,項目名稱:DealerTeam,代碼行數:35,代碼來源:DealerTeamController.php

示例2: createOrUpdateLegacyProductAttributeValue

 /**
  * Create or update the configuration for a legacy product attribute value.
  *
  * @param int $productId Product id.
  * @param int $attributeAvId Attribute value id.
  * @param int $currencyId Currency id.
  * @param float|null $priceDelta Price difference added (or removed) by the attribute value.
  *
  * @throws PropelException
  */
 protected function createOrUpdateLegacyProductAttributeValue($productId, $attributeAvId, $currencyId, $priceDelta = null)
 {
     if ($priceDelta === null) {
         return;
     }
     $legacyProductAttributeValue = LegacyProductAttributeValueQuery::create()->findPk([$productId, $attributeAvId]);
     if ($legacyProductAttributeValue === null) {
         $legacyProductAttributeValue = (new LegacyProductAttributeValue())->setProductId($productId)->setAttributeAvId($attributeAvId);
     }
     $legacyProductAttributeValuePriceDelta = LegacyProductAttributeValuePriceQuery::create()->findPk([$productId, $attributeAvId, $currencyId]);
     if ($legacyProductAttributeValuePriceDelta === null) {
         $legacyProductAttributeValuePriceDelta = (new LegacyProductAttributeValuePrice())->setProductId($productId)->setAttributeAvId($attributeAvId)->setCurrencyId($currencyId);
     }
     if ($priceDelta !== null) {
         $legacyProductAttributeValuePriceDelta->setDelta($priceDelta);
     }
     Propel::getConnection()->beginTransaction();
     try {
         $legacyProductAttributeValue->save();
         $legacyProductAttributeValuePriceDelta->save();
     } catch (PropelException $e) {
         Propel::getConnection()->rollBack();
         throw $e;
     }
     Propel::getConnection()->commit();
 }
開發者ID:bcbrr,項目名稱:LegacyProductAttributes,代碼行數:36,代碼來源:LegacyProductAttributesValuesController.php

示例3: install

 /**
  */
 public function install()
 {
     // install sql
     $files = ['sql/keeko.sql', 'data/static-data.sql', 'data/dummy-data.sql'];
     try {
         $repo = $this->getServiceContainer()->getResourceRepository();
         $con = Propel::getConnection();
         foreach ($files as $file) {
             if ($repo->contains('/iuf/junia/database/' . $file)) {
                 $sql = $repo->get('/iuf/junia/database/' . $file)->getBody();
                 $stmt = $con->prepare($sql);
                 $stmt->execute();
             }
         }
     } catch (\Exception $e) {
         echo $e->getMessage();
     }
     // install static data
     // 		$comp = new Competition();
     // 		$comp->setLabel('Individual Freestyle');
     // 		$comp->save();
     // 		$comp = new Competition();
     // 		$comp->setLabel('Pairs Freestyle');
     // 		$comp->save();
     // 		$comp = new Competition();
     // 		$comp->setLabel('Small Group Freestyle');
     // 		$comp->save();
     // 		$comp = new Competition();
     // 		$comp->setLabel('Large Group Freestyle');
     // 		$comp->save();
 }
開發者ID:iuf,項目名稱:junia,代碼行數:33,代碼來源:JuniaModule.php

示例4: CreateOverwriteByExternalTypeIdAndExternalId

 /**
  * Create a task with transaction into the data gateway
  *
  * @param Request  $request  Request that will contain attributes of the new entity to be created
  *
  * @throws EmptyArray When an empty array is found
  *
  * @return void
  */
 public function CreateOverwriteByExternalTypeIdAndExternalId(Request $request)
 {
     $con = Propel::getConnection();
     $con->beginTransaction();
     $this->retrieve(new Request(['externalTypeId' => $request->getData()['externalTypeId'], 'externalId' => $request->getData()['externalId']]));
     if (count($this->getEntitiesFromResponse()) > 0) {
         $con->rollBack();
         return;
     }
     /** @var \Tasker\Mapper\Task\Entity $mapper */
     $mapper = DbMapperFactory::make('task|entity');
     $mapper->setArrays($request->getData());
     /** @var \Tasker\DataGateway\Db\Entity\Task $task */
     $dbTaskCollection = $mapper->getMappedSecondEntities();
     if (!isset($dbTaskCollection[0])) {
         $con->rollBack();
         throw new EmptyArray('Array must be populated with one db entity', __FILE__, __LINE__);
     }
     /** @var ActiveRecordInterface $dbTask */
     $dbTask = $dbTaskCollection[0];
     $dbTask->save();
     $con->commit();
     $mapper->setArrays($dbTask->toArray());
     $this->setEntitiesFromResponse($mapper->getMappedFirstEntities());
 }
開發者ID:arkanmgerges,項目名稱:tasker,代碼行數:34,代碼來源:Task.php

示例5: execute

 /**
  * {@inheritdoc}
  */
 protected function execute(InputInterface $input, OutputInterface $output)
 {
     if (!$input->getOption('force')) {
         $output->writeln('<error>You have to use the "--force" option to drop the database.</error>');
         return;
     }
     if ('prod' === $this->getApplication()->getKernel()->getEnvironment()) {
         $this->writeSection($output, 'WARNING: you are about to drop a database in production !', 'bg=red;fg=white');
         if (false === $this->askConfirmation($input, $output, 'Are you sure ? (y/n) ', false)) {
             $output->writeln('Aborted, nice decision !');
             return -2;
         }
     }
     $connectionName = $input->getOption('connection') ?: $this->getDefaultConnection();
     $config = $this->getConnectionData($connectionName);
     $connection = Propel::getConnection($connectionName);
     $dbName = $this->parseDbName($config['dsn']);
     if (null === $dbName) {
         return $output->writeln('<error>No database name found.</error>');
     } else {
         $query = 'DROP DATABASE ' . $dbName . ';';
     }
     $statement = $connection->prepare($query);
     $statement->execute();
     $output->writeln(sprintf('<info>Database <comment>%s</comment> has been dropped.</info>', $dbName));
 }
開發者ID:naldz,項目名稱:cyberden,代碼行數:29,代碼來源:DatabaseDropCommand.php

示例6: deleteCard

 /**
  * @param Click $card
  */
 public function deleteCard($card)
 {
     $delete = "\n        DELETE FROM logintime t1\n   JOIN\n    (\n     SELECT MAX(datetime)\n      AS max_dt\n      FROM logintime\n      WHERE user_id = 1\n    ) t2\nWHERE t1.datetime  = t2.max_dt\n   AND card = {$card->get}\n   ";
     $con = Propel::getConnection();
     $stmt = $con->prepare($delete);
     return $stmt->execute();
 }
開發者ID:bassix,項目名稱:FreakXoHBingo,代碼行數:10,代碼來源:ClicksManager.php

示例7: register

 /**
  * {@inheritDoc}
  */
 public function register(Container $container)
 {
     // Append custom settings with missing params from default settings
     $container['settings']['database'] = self::mergeWithDefaultSettings($container['settings']['database']);
     $settings = $container['settings']['database'];
     $logLevel = $settings['logger']['level'] ?? null;
     $logPath = $settings['logger']['path'] ?? null;
     $className = $settings['classname'] ?? null;
     if (!$className) {
         $className = 'Propel\\Runtime\\Connection\\ConnectionWrapper';
         if ($logLevel == Logger::DEBUG) {
             $className = 'Propel\\Runtime\\Connection\\ProfilerConnectionWrapper';
         }
     }
     $manager = new ConnectionManagerSingle();
     $manager->setConfiguration(['classname' => $className, 'dsn' => $settings['dsn'], 'user' => $settings['user'], 'password' => $settings['password'], 'settings' => $settings['settings']]);
     $manager->setName($settings['connection']);
     /** @var StandardServiceContainer $serviceContainer */
     $serviceContainer = Propel::getServiceContainer();
     $serviceContainer->checkVersion($settings['version']);
     $serviceContainer->setAdapterClass($settings['connection'], $settings['adapter']);
     $serviceContainer->setConnectionManager($settings['connection'], $manager);
     $serviceContainer->setDefaultDatasource($settings['connection']);
     if ($logPath && $logLevel) {
         $logger = new Logger('defaultLogger');
         $logger->pushHandler(new StreamHandler($logPath, $logLevel));
         $serviceContainer->setLogger('defaultLogger', $logger);
         if ($logLevel == Logger::DEBUG) {
             /** @var ConnectionWrapper $con */
             $con = Propel::getConnection();
             $con->useDebug(true);
         }
     }
 }
開發者ID:ansas,項目名稱:php-component,代碼行數:37,代碼來源:PropelProvider.php

示例8: changeAppPhoto

 function changeAppPhoto($params)
 {
     require 'session.php';
     $con = Propel::getConnection('pos');
     $con->beginTransaction();
     $operationTime = time();
     $unique = session_id() . time();
     $file = $_FILES['photo'];
     $folder = $session->get('pos/folder') . '/resources/images/';
     $ext = pathinfo($file['name'], PATHINFO_EXTENSION);
     $newfile = $unique . '.' . $ext;
     $newfile_full_path = $folder . $newfile;
     try {
         if ($file['name'] == '') {
             throw new Exception('Missing file');
         }
         if ($file['error'] > 0) {
             throw new Exception($file['error']);
         }
         move_uploaded_file($file['tmp_name'], $newfile_full_path);
         $appPhoto = OptionQuery::create()->filterByName(['app_photo'])->findOne($con);
         $appPhoto->setValue($newfile)->save($con);
         $results['success'] = true;
         $results['photo'] = $newfile;
         $con->commit();
     } catch (Exception $e) {
         $con->rollBack();
         $results['success'] = false;
         $results['errmsg'] = $e->getMessage();
     }
     return $results;
 }
開發者ID:AlvaCorp,項目名稱:POS-2,代碼行數:32,代碼來源:Mains.php

示例9: load

 /**
  * {@inheritdoc}
  */
 public function load($files = array(), $connectionName)
 {
     $nbFiles = 0;
     $this->deletedClasses = array();
     $this->loadMapBuilders($connectionName);
     $this->con = Propel::getConnection($connectionName);
     try {
         $this->con->beginTransaction();
         $datas = array();
         foreach ($files as $file) {
             $content = $this->transformDataToArray($file);
             if (count($content) > 0) {
                 $datas = array_merge_recursive($datas, $content);
                 $nbFiles++;
             }
         }
         $this->deleteCurrentData($datas);
         $this->loadDataFromArray($datas);
         $this->con->commit();
     } catch (\Exception $e) {
         $this->con->rollBack();
         throw $e;
     }
     return $nbFiles;
 }
開發者ID:naldz,項目名稱:cyberden,代碼行數:28,代碼來源:AbstractDataLoader.php

示例10: createOrUpdate

 protected function createOrUpdate(PopInCampaignEvent $event, PopInCampaign $model)
 {
     $con = Propel::getConnection(PopInCampaignTableMap::DATABASE_NAME);
     $con->beginTransaction();
     try {
         if (null !== ($id = $event->getId())) {
             $model->setId($id);
         }
         if (null !== ($start = $event->getStart())) {
             $model->setStart($start);
         }
         if (null !== ($end = $event->getEnd())) {
             $model->setEnd($end);
         }
         if (null !== ($contentSourceType = $event->getContentSourceType())) {
             $model->setContentSourceType($contentSourceType);
         }
         if (null !== ($contentSourceId = $event->getContentSourceId())) {
             $model->setContentSourceId($contentSourceId);
         }
         $model->save($con);
         $con->commit();
     } catch (\Exception $e) {
         $con->rollback();
         throw $e;
     }
     $event->setPopInCampaign($model);
 }
開發者ID:bcbrr,項目名稱:PopIn,代碼行數:28,代碼來源:PopInCampaignAction.php

示例11: setUp

 /**
  * This is run before each unit test; it populates the database.
  */
 protected function setUp()
 {
     Propel::init(__DIR__ . '/../../../../Fixtures/bookstore/build/conf/bookstore-conf.php');
     parent::setUp();
     $this->con = Propel::getConnection(BookPeer::DATABASE_NAME);
     $this->con->beginTransaction();
 }
開發者ID:RafalFilipek,項目名稱:Propel2,代碼行數:10,代碼來源:BookstoreTestBase.php

示例12: testSimpleCountSql

 public function testSimpleCountSql()
 {
     $con = \Propel\Runtime\Propel::getConnection();
     $con->useDebug(true);
     $exec = QuerycacheTable1Query::create()->count($con);
     $expectedSql = $this->getSql("SELECT COUNT(*) FROM querycache_table1");
     $renderedSql = \Propel\Runtime\Propel::getConnection()->getLastExecutedQuery();
     $this->assertEquals($expectedSql, $renderedSql);
 }
開發者ID:naldz,項目名稱:cyberden,代碼行數:9,代碼來源:QueryCacheTest.php

示例13: __construct

 /**
  * Model constructor.
  */
 public function __construct()
 {
     if (USE_ORM === true) {
         $this->dbase = Propel::getConnection();
     } else {
         $this->_dbConfig = unserialize(DATABASE);
         $this->dbase = new Database($this->_dbConfig);
     }
 }
開發者ID:nenepadi,項目名稱:diy,代碼行數:12,代碼來源:Model.php

示例14: getCardClicksDataWithinSeconds

 /**
  * Get Card Clicks count within Seconds.
  *
  * @param int $seconds
  * @return array
  */
 public function getCardClicksDataWithinSeconds($seconds = 45)
 {
     $query = "\n            SELECT game_id,card,count(card) as clicks\n            FROM `bingo_click`\n            WHERE time_create > (NOW() - INTERVAL {$seconds} SECOND)\n            GROUP BY card\n            ORDER BY clicks DESC\n        ";
     $con = Propel::getConnection();
     $stmt = $con->prepare($query);
     $stmt->execute();
     $clickResult = $stmt->fetchAll(\PDO::FETCH_ASSOC);
     return $clickResult;
 }
開發者ID:eLtMosen,項目名稱:FreakXoHBingo,代碼行數:15,代碼來源:ClicksManager.php

示例15: saveOrder

 /**
  * @param \Generated\Shared\Transfer\QuoteTransfer $quoteTransfer
  * @param \Generated\Shared\Transfer\CheckoutResponseTransfer $checkoutResponseTransfer
  *
  * @return void
  */
 public function saveOrder(QuoteTransfer $quoteTransfer, CheckoutResponseTransfer $checkoutResponseTransfer)
 {
     $this->assertOrderRequirements($quoteTransfer);
     Propel::getConnection()->beginTransaction();
     $salesOrderEntity = $this->saveOrderEntity($quoteTransfer);
     $this->saveOrderItems($quoteTransfer, $salesOrderEntity);
     Propel::getConnection()->commit();
     $this->hydrateCheckoutResponseTransfer($checkoutResponseTransfer, $quoteTransfer, $salesOrderEntity);
 }
開發者ID:spryker,項目名稱:Sales,代碼行數:15,代碼來源:OrderSaver.php


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