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


PHP PDOException類代碼示例

本文整理匯總了PHP中PDOException的典型用法代碼示例。如果您正苦於以下問題:PHP PDOException類的具體用法?PHP PDOException怎麽用?PHP PDOException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: handleError

 public function handleError($model, $query, \PDOException $e)
 {
     // echo "*** Model in handleError: " . $model . "\n";
     switch ($e->getCode()) {
         // MySQL table missing
         case '42S02':
             // SQLite table missing
         // SQLite table missing
         case 'HY000' && stripos($e->getMessage(), "no such table") !== false:
             if ($model != 'StdClass') {
                 $instance = new $model();
                 if ($instance instanceof ActiveRecord) {
                     $table_builder = new TableBuilder($instance);
                     $table_builder->build();
                     return $this->query($query, $model);
                     // Re-run the query
                 }
             }
             throw new DatabaseLayer\TableDoesntExistException($e->getCode() . ": " . $e->getMessage());
         default:
             // Write exception to log.
             if (DatabaseLayer::getInstance()->getLogger()) {
                 DatabaseLayer::getInstance()->getLogger()->addError("Active Record Exception in " . $model . "\n\n" . $e->getCode() . ": " . $e->getMessage() . "\n\nrunning:\n\n{$query}");
             }
             throw new DatabaseLayer\Exception($e->getCode() . ": " . $e->getMessage() . ".\n\n" . $query);
     }
 }
開發者ID:Thruio,項目名稱:ActiveRecord,代碼行數:27,代碼來源:Base.php

示例2: throwExceptionWithInfo

 /**
  * Throw DbException with query info
  *
  * @param string        $sql
  * @param array         $params
  * @param \PDOException $e
  *
  * @throws DbException
  */
 protected function throwExceptionWithInfo($sql, array $params, \PDOException $e)
 {
     $exception = new DbException($e->getMessage(), (int) $e->getCode(), $e);
     $exception->setSql($sql);
     $exception->setParams($params);
     throw $exception;
 }
開發者ID:nafigator,項目名稱:Veles,代碼行數:16,代碼來源:PdoAdapter.php

示例3: renderPdoException

 /**
  * Render a PDOException.
  *
  * @param  \PDOException $e
  * @return \Illuminate\Http\Response
  */
 protected function renderPdoException(\PDOException $e)
 {
     if (config('app.debug', false) === true) {
         $message = explode(' ', $e->getMessage());
         $dbCode = rtrim($message[1], ']');
         $dbCode = trim($dbCode, '[');
         // codes specific to MySQL
         switch ($dbCode) {
             case 1049:
                 $userMessage = 'Unknown database - probably config error:';
                 break;
             case 2002:
                 $userMessage = 'DATABASE IS DOWN:';
                 break;
             case 1045:
                 $userMessage = 'Incorrect DB Credentials:';
                 break;
             default:
                 $userMessage = 'Untrapped Error:';
                 break;
         }
         $userMessage = $userMessage . '<br>' . $e->getMessage();
     } else {
         // be apologetic but never specific ;)
         $userMessage = 'We are currently experiencing a site wide issue. We are sorry for the inconvenience!';
     }
     return response($userMessage);
 }
開發者ID:xLink,項目名稱:Portfolio,代碼行數:34,代碼來源:Handler.php

示例4: __construct

 public function __construct(PDOException $e)
 {
     if (strstr($e->getMessage(), 'SQLSTATE[')) {
         preg_match('/SQLSTATE\\[(\\w+)\\] \\[(\\w+)\\] (.*)/', $e->getMessage(), $matches);
         $this->code = $matches[1] == 'HT000' ? $matches[2] : $matches[1];
         $this->message = $matches[3];
     }
 }
開發者ID:rafaelurrutia,項目名稱:bmonitor-y-bi,代碼行數:8,代碼來源:libs.connect.php

示例5: exception_formater

 private function exception_formater(PDOException $e)
 {
     if (strstr($e->getMessage(), 'SQLSTATE[')) {
         preg_match('/SQLSTATE\\[(\\w+)\\]: /', $e->getMessage(), $matches);
         $this->code = $matches[1] == 'HT000' ? $matches[2] : $matches[1];
     }
     $this->message = isset($this->err_code_msg[$this->code]) ? $this->err_code_msg[$this->code] : $e->getMessage();
 }
開發者ID:socialweb,項目名稱:PiGo,代碼行數:8,代碼來源:IzapSqlite.php

示例6: __construct

 public function __construct(\PDOException $e, $extraMessage = '')
 {
     // Strip boring unnecessary info from error message
     $strippedMsg = preg_replace('/SQLSTATE\\[[A-Za-z-0-9]+\\]( \\[[A-Za-z-0-9]+\\])?:?\\s?/', '', $e->getMessage());
     // PDOExceptions' getCode() can  return a code with letters, which normal
     // exceptions won't accept. A converted code is better than no code at all though.
     parent::__construct($strippedMsg . $extraMessage, (int) $e->getCode());
 }
開發者ID:starweb,項目名稱:starlit-db,代碼行數:8,代碼來源:DbException.php

示例7: createFromPDOException

 /**
  * @param \PDOException $exception
  * @return MySqlException
  */
 public static function createFromPDOException(\PDOException $exception)
 {
     $message = $exception->getMessage();
     $codePosition = strpos($message, "[{$exception->getCode()}]");
     if ($codePosition !== false) {
         $message = trim(substr($message, $codePosition + strlen("[{$exception->getCode()}]") + 1));
     }
     return new MySqlException($message, $exception->getCode());
 }
開發者ID:oktopost,項目名稱:squid,代碼行數:13,代碼來源:MySqlException.php

示例8: throwException

 /**
  * @param PDOException $exception
  */
 public function throwException(PDOException $exception)
 {
     if ($this->debug) {
         echo '<pre>';
         print_r(array($exception->getMessage(), $exception->getCode()));
         echo '</pre>';
         die;
     }
 }
開發者ID:AdrianTrainorPHP,項目名稱:FormHandler,代碼行數:12,代碼來源:CustomPDO.php

示例9: pdoError

 /**
  * Convenience method to display a PDOException.
  *
  * @param PDOException $error
  * @return void
  */
 public function pdoError(PDOException $error)
 {
     $url = $this->controller->request->here();
     $code = 500;
     $this->controller->response->statusCode($code);
     $this->controller->set(array('code' => $code, 'url' => h($url), 'name' => $error->getMessage(), 'error' => $error, '_serialize' => array('code', 'url', 'name', 'error')));
     $message = "<table cellpadding='1' cellspacing='1' align='left' width='100%'>\n\t\t\t\t\t<tr><td>&nbsp;</td></tr>\n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'>Hi, </td></tr>\n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'>A user is trying to do an activity on OS but not able to proceed due to below error </td></tr>\n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'>&nbsp;</td></tr>\t   \n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'><font color='#EE0000;'>" . $error->getMessage() . "</font> </td></tr>\t   \n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'>&nbsp;</td></tr>\n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'><b>Domain:</b> " . HTTP_ROOT . "</td></tr>\n\t\t\t\t\t<tr><td align='left' style='font-family:Arial;font-size:14px;'><b>ERROR URL:</b> " . h($url) . "</td></tr>\n\t\t\t\t\t<tr height='25px'><td>&nbsp;</td></tr></table>";
     $subject = "DATABASE ERROR";
     $this->Postcase->sendGridEmail(SUPPORT_EMAIL, DEV_EMAIL, $subject, $message, 'Exception');
     $this->_outputMessage($this->template);
 }
開發者ID:lexdk,項目名稱:Orangescrum_Installation,代碼行數:17,代碼來源:AppExceptionRenderer.php

示例10: handleException

 /**
  * Handles exception by either printing it to the screen with other useful information (dev mode)
  * or logging the exception.
  * 
  * @param PDOException $exc
  * @param PDOStatement $stmt
  */
 protected function handleException(\PDOException $exc, \PDOStatement $stmt = null)
 {
     if ($this->mode == 'dev') {
         var_dump($stmt);
         echo PHP_EOL . $exc->getMessage() . PHP_EOL;
     } else {
         if ($this->mode == 'prod') {
             error_log($exc->getMessage());
         }
     }
 }
開發者ID:bashedev,項目名稱:Db,代碼行數:18,代碼來源:Db.php

示例11: PDOException

 protected function PDOException(PDOException $exception, $display_type)
 {
     switch ($display_type) {
         case 1000:
             return json_encode(array('status' => 'PDOException', 'message' => $exception->getMessage()));
         case 2000:
             return array('status' => 'PDOException', 'message' => $exception->getMessage());
         case 3000:
             return 'PDOException: ' . $exception->getMessage();
     }
     return FALSE;
 }
開發者ID:tfont,項目名稱:skyfire,代碼行數:12,代碼來源:DB_Connector.php

示例12: testConstruct

 /**
  * @covers       Veles\DataBase\Exceptions\DbException::__construct
  *
  * @param string        $message
  * @param string        $ansi_code
  * @param int           $code
  * @param \PDOException $exception
  *
  * @dataProvider constructProvider
  */
 public function testConstruct($message, $ansi_code, $code, $exception)
 {
     $obj = new DbException($exception->getMessage(), (int) $exception->getCode(), $exception);
     $result = $obj->getMessage();
     $msg = 'Wrong DbException::__construct() behavior!';
     $this->assertSame($message, $result, $msg);
     $result = $obj->getAnsiCode();
     $msg = 'Wrong DbException::__construct() behavior!';
     $this->assertSame($ansi_code, $result, $msg);
     $result = $obj->getCode();
     $msg = 'Wrong DbException::__construct() behavior!';
     $this->assertSame($code, $result, $msg);
 }
開發者ID:nafigator,項目名稱:Veles-unit-tests,代碼行數:23,代碼來源:DbExceptionTest.php

示例13: raw_query

 /**
  * Run RAW Query
  *
  * @param string $sql
  *
  * @return Zend_Db_Statement_Interface
  * @throws PDOException
  */
 public function raw_query($sql)
 {
     try {
         return $this->query($sql);
     } catch (Zend_Db_Statement_Exception $e) {
         // Convert to PDOException to maintain backwards compatibility with usage of MySQL adapter
         $e = $e->getPrevious();
         if (!$e instanceof PDOException) {
             $e = new PDOException($e->getMessage(), $e->getCode());
         }
         throw $e;
     }
 }
開發者ID:dburlage-pantek,項目名稱:Aoe_DbRetry,代碼行數:21,代碼來源:Adapter.php

示例14: processPDOException

	/**
	 * @param \PDOException
	 * @throws \Nella\Models\Exception
	 * @throws \Nella\Models\EmptyValueException
	 * @throws \Nella\Models\DuplicateEntryException
	 */
	protected function processPDOException(\PDOException $e)
	{
		$info = $e->errorInfo;
		if ($info[0] == 23000 && $info[1] == 1062) { // unique fail
			// @todo how to detect column name ?
			throw new \Nella\Models\DuplicateEntryException($e->getMessage(), NULL, $e);
		} elseif ($info[0] == 23000 && $info[1] == 1048) { // notnull fail
			// @todo convert table column name to entity column name
			$name = substr($info[2], strpos($info[2], "'") + 1);
			$name = substr($name, 0, strpos($name, "'"));
			throw new \Nella\Models\EmptyValueException($e->getMessage(), $name, $e);
		} else { // other fail
			throw new \Nella\Models\Exception($e->getMessage(), 0, $e);
		}
	}
開發者ID:norbe,項目名稱:framework,代碼行數:21,代碼來源:Service.php

示例15: convertException

 public function convertException(\PDOException $e)
 {
     $code = isset($e->errorInfo[1]) ? $e->errorInfo[1] : NULL;
     $msg = $e->getMessage();
     if ($code !== 19) {
         return Nette\Database\DriverException::from($e);
     } elseif (strpos($msg, 'must be unique') !== FALSE || strpos($msg, 'is not unique') !== FALSE || strpos($msg, 'UNIQUE constraint failed') !== FALSE) {
         return Nette\Database\UniqueConstraintViolationException::from($e);
     } elseif (strpos($msg, 'may not be NULL') !== FALSE || strpos($msg, 'NOT NULL constraint failed') !== FALSE) {
         return Nette\Database\NotNullConstraintViolationException::from($e);
     } elseif (strpos($msg, 'foreign key constraint failed') !== FALSE || strpos($msg, 'FOREIGN KEY constraint failed') !== FALSE) {
         return Nette\Database\ForeignKeyConstraintViolationException::from($e);
     } else {
         return Nette\Database\ConstraintViolationException::from($e);
     }
 }
開發者ID:remicollet,項目名稱:database,代碼行數:16,代碼來源:SqliteDriver.php


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