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


PHP DBALException::invalidPdoInstance方法代碼示例

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


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

示例1: getConnection

 /**
  * Creates a connection object based on the specified parameters.
  * This method returns a Doctrine\DBAL\Connection which wraps the underlying
  * driver connection.
  *
  * $params must contain at least one of the following.
  *
  * Either 'driver' with one of the following values:
  *     pdo_mysql
  *     pdo_sqlite
  *     pdo_pgsql
  *     pdo_oracle
  *     pdo_sqlsrv
  *
  * OR 'driverClass' that contains the full class name (with namespace) of the
  * driver class to instantiate.
  *
  * Other (optional) parameters:
  *
  * <b>user (string)</b>:
  * The username to use when connecting.
  *
  * <b>password (string)</b>:
  * The password to use when connecting.
  *
  * <b>driverOptions (array)</b>:
  * Any additional driver-specific options for the driver. These are just passed
  * through to the driver.
  *
  * <b>pdo</b>:
  * You can pass an existing PDO instance through this parameter. The PDO
  * instance will be wrapped in a Doctrine\DBAL\Connection.
  *
  * <b>wrapperClass</b>:
  * You may specify a custom wrapper class through the 'wrapperClass'
  * parameter but this class MUST inherit from Doctrine\DBAL\Connection.
  *
  * <b>driverClass</b>:
  * The driver class to use.
  *
  * @param array $params The parameters.
  * @param Doctrine\DBAL\Configuration The configuration to use.
  * @param Doctrine\Common\EventManager The event manager to use.
  * @return Doctrine\DBAL\Connection
  */
 public static function getConnection(array $params, Configuration $config = null, EventManager $eventManager = null)
 {
     // create default config and event manager, if not set
     if (!$config) {
         $config = new Configuration();
     }
     if (!$eventManager) {
         $eventManager = new EventManager();
     }
     // check for existing pdo object
     if (isset($params['pdo']) && !$params['pdo'] instanceof \PDO) {
         throw DBALException::invalidPdoInstance();
     } else {
         if (isset($params['pdo'])) {
             $params['pdo']->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
             $params['driver'] = 'pdo_' . $params['pdo']->getAttribute(\PDO::ATTR_DRIVER_NAME);
         } else {
             self::_checkParams($params);
         }
     }
     if (isset($params['driverClass'])) {
         $className = $params['driverClass'];
     } else {
         $className = self::$_driverMap[$params['driver']];
     }
     $driver = new $className();
     $wrapperClass = 'Doctrine\\DBAL\\Connection';
     if (isset($params['wrapperClass'])) {
         if (is_subclass_of($params['wrapperClass'], $wrapperClass)) {
             $wrapperClass = $params['wrapperClass'];
         } else {
             throw DBALException::invalidWrapperClass($params['wrapperClass']);
         }
     }
     return new $wrapperClass($params, $driver, $config, $eventManager);
 }
開發者ID:pollux1er,項目名稱:dlawebdev2,代碼行數:81,代碼來源:DriverManager.php

示例2: getConnection

 /**
  * Creates a connection object based on the specified parameters.
  * This method returns a Doctrine\DBAL\Connection which wraps the underlying
  * driver connection.
  *
  * $params must contain at least one of the following.
  *
  * Either 'driver' with one of the following values:
  *
  *     pdo_mysql
  *     pdo_sqlite
  *     pdo_pgsql
  *     pdo_oci (unstable)
  *     pdo_sqlsrv
  *     pdo_sqlsrv
  *     mysqli
  *     sqlanywhere
  *     sqlsrv
  *     ibm_db2 (unstable)
  *     drizzle_pdo_mysql
  *
  * OR 'driverClass' that contains the full class name (with namespace) of the
  * driver class to instantiate.
  *
  * Other (optional) parameters:
  *
  * <b>user (string)</b>:
  * The username to use when connecting.
  *
  * <b>password (string)</b>:
  * The password to use when connecting.
  *
  * <b>driverOptions (array)</b>:
  * Any additional driver-specific options for the driver. These are just passed
  * through to the driver.
  *
  * <b>pdo</b>:
  * You can pass an existing PDO instance through this parameter. The PDO
  * instance will be wrapped in a Doctrine\DBAL\Connection.
  *
  * <b>wrapperClass</b>:
  * You may specify a custom wrapper class through the 'wrapperClass'
  * parameter but this class MUST inherit from Doctrine\DBAL\Connection.
  *
  * <b>driverClass</b>:
  * The driver class to use.
  *
  * @param array                              $params       The parameters.
  * @param \Doctrine\DBAL\Configuration|null  $config       The configuration to use.
  * @param \Doctrine\Common\EventManager|null $eventManager The event manager to use.
  *
  * @return \Doctrine\DBAL\Connection
  *
  * @throws \Doctrine\DBAL\DBALException
  */
 public static function getConnection(array $params, Configuration $config = null, EventManager $eventManager = null)
 {
     // create default config and event manager, if not set
     if (!$config) {
         $config = new Configuration();
     }
     if (!$eventManager) {
         $eventManager = new EventManager();
     }
     $params = self::parseDatabaseUrl($params);
     // check for existing pdo object
     if (isset($params['pdo']) && !$params['pdo'] instanceof \PDO) {
         throw DBALException::invalidPdoInstance();
     } else {
         if (isset($params['pdo'])) {
             $params['pdo']->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
             $params['driver'] = 'pdo_' . $params['pdo']->getAttribute(\PDO::ATTR_DRIVER_NAME);
         } else {
             self::_checkParams($params);
         }
     }
     if (isset($params['driverClass'])) {
         $className = $params['driverClass'];
     } else {
         $className = self::$_driverMap[$params['driver']];
     }
     $driver = new $className();
     $wrapperClass = 'Doctrine\\DBAL\\Connection';
     if (isset($params['wrapperClass'])) {
         if (is_subclass_of($params['wrapperClass'], $wrapperClass)) {
             $wrapperClass = $params['wrapperClass'];
         } else {
             throw DBALException::invalidWrapperClass($params['wrapperClass']);
         }
     }
     if (self::$instance === null) {
         self::$instance = 1;
         //add new Cassandra types
         Type::addType('cassandra_float', 'CassandraPDO4Doctrine\\Doctrine\\DBAL\\Types\\CassandraFloatType');
         Type::addType('cassandra_datetime', 'CassandraPDO4Doctrine\\Doctrine\\DBAL\\Types\\CassandraDateTimeType');
     }
     return new $wrapperClass($params, $driver, $config, $eventManager);
 }
開發者ID:balalaikaboy,項目名稱:CassandraPDO4Doctrine,代碼行數:98,代碼來源:DriverManager.php


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