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


PHP PDOStatement::errorCode方法代碼示例

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


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

示例1: execute

 public function execute($input_parameters = NULL)
 {
     if (APF::get_instance()->is_debug_enabled()) {
         APF::get_instance()->debug(__CLASS__ . '[' . $this->pdo->config['dsn'] . '|' . $this->pdo->get_name() . ']' . "->execute: " . $this->queryString);
     }
     $logger = APF::get_instance()->get_logger();
     $logger->debug(__CLASS__, '[' . $this->pdo->get_name() . ']->execute: ', $this->queryString);
     APF::get_instance()->pf_benchmark_inc_begin('dbtime');
     $start = microtime(true);
     $ret = parent::execute($input_parameters);
     $end = microtime(true);
     APF::get_instance()->pf_benchmark_inc_end('dbtime');
     //add by hexin for record SQL execute time
     APF::get_instance()->pf_benchmark("sql_time", array($this->i => $end - $start));
     if (!$ret) {
         $error_info = parent::errorInfo();
         $logger->error(__CLASS__, '[' . $this->pdo->get_name() . ']->execute: ', $this->queryString);
         $_error_info = preg_replace("#[\r\n \t]+#", ' ', print_r($error_info, true));
         $logger->error(__CLASS__, '[' . $this->pdo->get_name() . ']->execute: ', $_error_info);
         if (parent::errorCode() !== '00000') {
             trigger_error($this->queryString . ' | ' . join(' | ', $error_info), E_USER_ERROR);
         }
     }
     return $ret;
 }
開發者ID:rh20083907,項目名稱:ipublish,代碼行數:25,代碼來源:PDOStatement.php

示例2: errorCode

 public function errorCode()
 {
     if ($this->_statement instanceof \PDOStatement) {
         return $this->_statement->errorCode();
     }
     return null;
 }
開發者ID:rtshome,項目名稱:pgbabylon,代碼行數:7,代碼來源:PDOStatement.php

示例3: getErrorNumber

 /**
  * Returns the number of the last error.
  * 
  * @return integer
  */
 public function getErrorNumber()
 {
     if ($this->pdoStatement !== null) {
         return $this->pdoStatement->errorCode();
     }
     return 0;
 }
開發者ID:ZerGabriel,項目名稱:WCF,代碼行數:12,代碼來源:PreparedStatement.class.php

示例4: errorCode

 /**
  * Renvoi le code de la dernière erreur
  *
  */
 public function errorCode()
 {
     if (is_object($this->stmt)) {
         $code = $this->stmt->errorCode();
         return PDO::ERR_NONE == $code ? null : $code;
     }
 }
開發者ID:Qwaseur,項目名稱:SACoche,代碼行數:11,代碼來源:DB_driver_PDO.class.php

示例5: execute

 public function execute($input_parameters = NULL)
 {
     if (APF::get_instance()->is_debug_enabled()) {
         APF::get_instance()->debug(__CLASS__ . '[' . $this->pdo->config['dsn'] . '|' . $this->pdo->get_name() . ']' . "->execute: " . $this->queryString);
     }
     $logger = APF::get_instance()->get_logger();
     $logger->debug(__CLASS__, '[' . $this->pdo->get_name() . ']->execute: ', $this->queryString);
     APF::get_instance()->pf_benchmark_inc_begin('dbtime');
     $start = microtime(true);
     $ret = parent::execute($input_parameters);
     $end = microtime(true);
     APF::get_instance()->pf_benchmark_inc_end('dbtime');
     //add by hexin for record SQL execute time
     APF::get_instance()->pf_benchmark("sql_time", array($this->i => $end - $start));
     // 按照慣用格式記錄sql執行時間和占用內存
     // added by htlv
     $tmp_time = $end - $start;
     $tmp_mem = memory_get_usage();
     apf_require_class('APF_Performance');
     APF::get_instance()->pf_benchmark("sql_time_af", array($this->i => array('sql' => $this->_sql, APF_Performance::MESSAGE_TIME => $tmp_time, APF_Performance::MESSAGE_MEMORY => $tmp_mem)));
     if (!$ret) {
         $error_info = parent::errorInfo();
         /**
          * remove duplicated error log
         $logger->error(__CLASS__, '['. $this->pdo->get_name() .']->execute: ', $this->queryString);
         $_error_info = preg_replace("#[\r\n \t]+#",' ',print_r($error_info,true));
         $logger->error(__CLASS__, '['. $this->pdo->get_name() .']->execute: ', $_error_info);
         */
         if (parent::errorCode() !== '00000') {
             throw new APF_Exception_SqlException($this->pdo->get_name() . ' | ' . $this->pdo->config['dsn'] . ' | ' . $this->queryString . ' | ' . join(' | ', $error_info), parent::errorCode());
         }
     }
     return $ret;
 }
開發者ID:emilymwang8,項目名稱:cms,代碼行數:34,代碼來源:PDOStatement.php

示例6: __construct

 public function __construct($message, PDOStatement $statement)
 {
     $infos = array();
     foreach ($statement->errorInfo() as $key => $info) {
         $infos[] = $key . ': ' . $info;
     }
     parent::__construct($message . '. (ERRNO ' . $statement->errorCode() . ') ' . implode('<br />', $infos));
 }
開發者ID:AroundPBT,項目名稱:PHPBoost,代碼行數:8,代碼來源:PDOQuerierException.class.php

示例7: errorCode

 /**
  * Returns the last error code generated by the wrapped PDO object. Please
  * the PDOStatement::errorCode method for prepared statements.
  *
  * @access public
  * @author Jerome Bogaerts, <jerome@taotesting.com>
  * @return string
  */
 private function errorCode()
 {
     if ($this->preparedExec == false) {
         $returnValue = $this->dbConnector->errorCode();
     } else {
         $returnValue = $this->lastPreparedExecStatement->errorCode();
     }
     return (string) $returnValue;
 }
開發者ID:nagyist,項目名稱:generis,代碼行數:17,代碼來源:class.Driver.php

示例8: errorCode

 /**
  * Retrieves the error code, if any, associated with the last operation on
  * the statement handle.
  *
  * @return string error code.
  * @throws Zend_Db_Statement_Exception
  */
 public function errorCode()
 {
     try {
         return $this->_stmt->errorCode();
     } catch (PDOException $e) {
         require_once 'Zend/Db/Statement/Exception.php';
         throw new Zend_Db_Statement_Exception($e->getMessage());
     }
 }
開發者ID:jorgenils,項目名稱:zend-framework,代碼行數:16,代碼來源:Pdo.php

示例9: query

	/**
	 * Permet d'exécuter une requête.
	 *
	 * Aucun résultat n'est renvoyé par cette fonction. Elle doit être utilisé pour effectuer
	 * des insertions, des updates... Elle est de même utilisée par les
	 * autres fonction de la classe comme queryRow() et queryTab().
	 *
	 * @param string $query chaine SQL
	 * @param mixed $param variables bind de type array(":bind"=>"value")
	 * @return void
	 */
	public function query($query, $param = array()) {

		global $sysNbQuery;

		// execution de la requête
		$this->query = (isset($_SERVER['HOSTNAME']) ? '/*SIG'.$_SERVER['HOSTNAME'].'SIG*/ ' : '').$query;
		$this->param = $param;
		$this->errorParams = array();
		$this->errorParams['Request'] = $query;
		$this->errorParams['Bind'] = $param;

		$this->id->setAttribute(PDO::ATTR_AUTOCOMMIT, $this->getCommitMode());
		$this->id->setAttribute(PDO::ATTR_EMULATE_PREPARES, true);

		$sysNbQuery = (!isset($sysNbQuery) || $sysNbQuery<=0) ? 1 : $sysNbQuery+1;
		
		// Prepare de la requête
		$queryMD5 = md5($query);					
		if(!isset($this->aPrepare[$queryMD5])) {
    	$this->lPrepare = $this->id->prepare($this->query);
    	$this->aPrepare[$queryMD5] = $this->lPrepare;
		} else {
			$this->lPrepare = $this->aPrepare[$queryMD5];
		}  

		if ($this->lPrepare!==false) {
			// Bind des paramètres
			if($param) {
				foreach($param as $key => $val) {
					if (strpos($query, $key) !== false) {
						if($param[$key]===null) $this->lPrepare->bindParam(trim($key), $param[$key], PDO::PARAM_NULL);
						else $this->lPrepare->bindParam(trim($key), $param[$key]);
					}
				}
			}
			
			// Execution de la requête
			$rs = $this->lPrepare->execute();
			
			if ($this->lPrepare->errorCode() != PDO::ERR_NONE) {
				$this->errorParams['errorInfo'] = $this->lPrepare->errorInfo();
				//echo'<xmp>Erreur execute() de PDO : '.$this->errorParams['errorInfo'][2];print_r($query);echo'</xmp>';
				//Génération d'une DataBaseException
				//throw new DataBaseException("Erreur execute() de PDO",$error[2],$this->errorParams);
			}
			
			return $rs;
			
		}else{
			$this->errorParams['errorInfo'] = $this->lPrepare->errorInfo();
			//echo'<xmp>Erreur prepare() de PDO : '.$this->errorParams['errorInfo'][2];print_r($query);echo'</xmp>';
			//DatabaseManager::log($this, true);
			//throw new DataBaseException("Erreur prepare() de PDO",$this->id->errorInfo(),$this->errorParams);
		}
		return false;
	}
開發者ID:rhertzog,項目名稱:lcs,代碼行數:67,代碼來源:DAO.class.php

示例10: isFailure

 /**
  * @param PDOStatement|boolean $sth
  * @param mixed $result
  * @return boolean TRUE if $result indicates failure, FALSE otherwise
  */
 private function isFailure($sth, $result)
 {
     if ($result === false) {
         $error = $sth->errorInfo();
         $this->lastError = 'DB ERROR: [' . $sth->errorCode() . '] ' . $error[2];
         error_log($this->lastError);
         return true;
     }
     return false;
 }
開發者ID:enygma,項目名稱:modler,代碼行數:15,代碼來源:Mysql.php

示例11: __construct

 /**
  * Constructor.
  *
  * @param \PDOStatement $pdoStatement
  * @param mixed $mapFunction
  * @param int $fetchStyle Controls how the row will be returned
  *
  * @throws \Quaver\Core\QException
  */
 public function __construct($pdoStatement, $mapFunction, $fetchStyle = \PDO::ATTR_DEFAULT_FETCH_MODE)
 {
     if ($pdoStatement->errorCode() != 0) {
         throw new QException('PDO statement with errors');
     }
     $this->stm = $pdoStatement;
     $this->mapFunction = $mapFunction;
     $this->fetchStyle = $fetchStyle;
     $this->cur = 0;
     $this->count = $pdoStatement->rowCount();
     $this->next();
 }
開發者ID:millolab,項目名稱:quaver-core,代碼行數:21,代碼來源:NoRewindIterator.php

示例12: execute

 /**
  * Executes the statement.
  * 
  * @return boolean
  * @throws DBQueryException
  */
 public function execute()
 {
     $start = microtime(true);
     $this->query->execute();
     $end = microtime(true);
     $sql = (string) $this->query->queryString;
     $error_id = (int) $this->query->errorCode();
     if ($this->callback) {
         $time = ($end - $start) * 1000;
         call_user_func_array($this->callback, array($sql, $time));
     }
     if ($error_id) {
         $error = $this->query->errorInfo();
         $message = "Database query error: ({$error[0]}/{$error[1]}) {$error[2]} in query [{$sql}]";
         throw new DBQueryException($message, E_USER_WARNING);
         return false;
     }
     $this->key = 0;
     $this->count = $this->query->rowCount();
     $this->current = $this->query->fetch();
 }
開發者ID:Acidburn0zzz,項目名稱:OEM,代碼行數:27,代碼來源:DBResult.php

示例13: execute

 public function execute($inputParameters = array())
 {
     $ret = parent::execute($inputParameters);
     Debugger::getInstance()->debug('SQL:' . $this->queryString . ';params:' . var_export($inputParameters, true));
     if (!$ret) {
         $error_info = parent::errorInfo();
         if (parent::errorCode() != '00000') {
             // 執行成功時返回五個零
             LoggerFactory::getLogger()->error('PDO executed failed,errors:' . var_export($error_info, true));
             trigger_error($this->queryString, E_USER_ERROR);
         }
     }
     return $ret;
 }
開發者ID:zhxia,項目名稱:nspf,代碼行數:14,代碼來源:Statement.php

示例14: rewind

 /**
  *
  * @see Iterator::rewind()
  */
 public function rewind()
 {
     //Dirty hack because rewind() is called before entering the loop
     //and on object creation we already have query executed
     if ($this->_needsRefresh) {
         $this->_refresh();
     } else {
         $this->_needsRefresh = true;
     }
     $this->_currentRowObj = $this->_statement->fetchObject('\\phpSweetPDO\\RecordsetRow');
     if ($this->_statement->errorCode() !== '00000') {
         throw new DbException($this->_statement->errorInfo(), $this->_statement->queryString);
     }
 }
開發者ID:neevan1e,項目名稱:Done,代碼行數:18,代碼來源:db.recordset.class.php

示例15: execute

 /**
  * Executes the query that was previously passed to the constructor.
  *
  * @param mixed  $arg      Query arguments to escape and insert at ? placeholders in $query
  * @param mixed  ...       Additional arguments
  **/
 public function execute()
 {
     // We can't very well perform a query wtihout an active connection.
     if (!is_object($this->dbh)) {
         $this->db->error('Lost connection to database.');
         return;
     }
     // end if
     // Finish any previous statements
     $this->finish();
     // We need to pre-process the arguments for literals and bytefields.  We
     // can't safely pass them into the PDO placeholder system, so we'll
     // have to stick them into the query at the right places before then.
     $args = Database::smart_args(func_get_args());
     list($query, $nargs, $nargn) = $this->reprocess_query($args);
     if (!$query) {
         return;
     }
     $this->last_query = $this->unprocess_query($query, $nargn);
     // Wrap the actual query execution in a bit of benchmarking.
     $before = microtime(true);
     $this->last_exception = null;
     try {
         // We will always create a new statement.  The possibility of missing
         // & pre-replaced placeholders breaks our ability to work with actual
         // prepared statements.  Additionally, PDO tends to break easily when
         // working on prepared statements that return multiple result sets
         // combined with multiple concurrent statement handles.  See the
         // comments on the PDOStatement::closeCursor() manual page.
         // Skip preparing the query if there are no args in the query.
         if ($nargn == 0) {
             $this->sh = $this->dbh->query($this->last_query);
         } else {
             $this->sh = $this->dbh->prepare($this->last_query);
             $this->sh->execute($nargs);
         }
     } catch (PDOException $e) {
         $this->last_exception = $e;
         $this->db->error('SQL Error:');
         return false;
     }
     // end try
     $after = microtime(true);
     $this->db->mysql_time += $after - $before;
     // The other adapters handle these here.  Fun times.
     // Problem 1:
     //  PDO does not provide a clear way to get the last inserted primary key.
     //  There's PDO::lastInsertId(), but it's poorly supported and sometimes
     //  requires extra arguments be passed.  There's undoubtedly a better
     //  way to deal with this than to not deal with it.
     $this->insert_id = null;
     // Problem 2:
     //  PDOStatement::rowCount()'s manual page says:
     //   "If the last SQL statement executed by the associated PDOStatement
     //    was a SELECT statement, some databases may return the number of
     //    rows returned by that statement. However, this behaviour is not
     //    guaranteed for all databases and should not be relied on for
     //    portable applications."
     //  So, unlike the other adapters, there's no separate call for getting
     //  the number of returned rows vs the number of affected rows.
     //  We'll just use it here and hope it works and that calling code doesn't
     //  care too much.
     // Overall, PDO kind of sucks for this kind of thing.
     $this->affected_rows = $this->sh->rowCount();
     $this->num_rows = $this->sh->rowCount();
     // PDO has no way to check warnings.  We won't try.
     $this->warnings = array();
     // But we do have errors, though this *should* never be called thanks to the
     // exception catching above.
     $last_notice = $this->sh->errorCode();
     if ($last_notice == '00000' || empty($last_notice)) {
         $last_notice = null;
     }
     if ($last_notice) {
         $this->db->error('SQL Error:');
         return false;
     }
     return true;
 }
開發者ID:qbdsoft,項目名稱:Query-Digest-UI,代碼行數:85,代碼來源:pdo.php


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