扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:朱先忠编译 来源:天极开发 2007年10月21日
关键字: Linux
/** *查询异常 * *当试图执行一个查询时,如果一个错误发生,将由{@link DBQuery}对象抛出错误 */ class QueryException extends Exception { /** * 查询文本 * * @var字符串$QueryText; */ protected $QueryText; /** *来自数据库的错误号/代码 * * @var字符串$ErrorCode */ protected $ErrorNumber; /** *来自数据库的错误消息 * * @var字符串$ErrorMessage */ protected $ErrorMessage; /** *类构造器 * * @参数:DBQuery $db,是抛出异常的查询对象 */ public function __construct(DBQuery $query) { /*得到调用栈*/ $backtrace = $this->GetTrace(); /*把行和文件设置到错误实际发生的位置*/ if (count($backtrace) > 0) { $x = 1; /*如果查询类被继承,那么我们需要忽略由子类所进行的调用*/ while((! isset($backtrace[$x]['line'])) || (isset($backtrace[$x]['class']) && is_subclass_of($backtrace[$x]['class'], 'DBQuery')) || (strpos(strtolower(@$backtrace[$x]['function']), 'call_user_func')) !== false ) { /*循环执行,只要没有行号或调用的函数是DBQuery类的一个子类*/ ++$x; /*如果我们到达栈底,那么我们使用第一个调用者*/ if (($x) >= count($backtrace)) { $x = count($backtrace); break; } } /*如果上面的循环至少执行一次,那么我们可以把它减1以查找实际的引起错误的代码行 */ if ($x != 1) { $x -= 1; } /*最后,我们可以设置文件和行号,这应该可以反映出引起错误的SQL语句*/ $this->line = $backtrace[$x]['line']; $this->file = $backtrace[$x]['file']; } $this->QueryText = $query->getCompiledQuery(); $this->ErrorNumber = $query->getDB()->errno(); $this->ErrorMessage = $query->getDB()->error(); /*调用超类的异常构造器*/ parent::__construct('Query Error', 0); } /** *得到查询文本 * * @返回字符串查询文本 */ public function GetQueryText() { return $this->QueryText; } /** *得到错误号 * * @返回字符串错误号 */ public function GetErrorNumber() { return $this->ErrorNumber; } /** *得到错误消息 * * @返回字符串错误消息 */ public function GetErrorMessage() { return $this->ErrorMessage; } /** *当对象被转换为一个字符串时调用。 * @返回字符串 */ public function __toString() { $output = "Query Error in {$this->file} on line {$this->line}nn"; $output .= "Query: {$this->QueryText}n"; $output .= "Error: {$this->ErrorMessage} ({$this->ErrorNumber})nn"; return $output; } } |
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者