Exception.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\db;
  8. /**
  9. * Exception represents an exception that is caused by some DB-related operations.
  10. *
  11. * @author Qiang Xue <qiang.xue@gmail.com>
  12. * @since 2.0
  13. */
  14. class Exception extends \yii\base\Exception
  15. {
  16. /**
  17. * @var array the error info provided by a PDO exception. This is the same as returned
  18. * by [PDO::errorInfo](https://www.php.net/manual/en/pdo.errorinfo.php).
  19. */
  20. public $errorInfo = [];
  21. /**
  22. * Constructor.
  23. * @param string $message PDO error message
  24. * @param array $errorInfo PDO error info
  25. * @param string $code PDO error code
  26. * @param \Throwable|null $previous The previous exception used for the exception chaining.
  27. */
  28. public function __construct($message, $errorInfo = [], $code = '', $previous = null)
  29. {
  30. parent::__construct($message, 0, $previous);
  31. $this->errorInfo = $errorInfo;
  32. $this->code = $code;
  33. }
  34. /**
  35. * @return string the user-friendly name of this exception
  36. */
  37. public function getName()
  38. {
  39. return 'Database Exception';
  40. }
  41. /**
  42. * @return string readable representation of exception
  43. */
  44. public function __toString()
  45. {
  46. return parent::__toString() . PHP_EOL
  47. . 'Additional Information:' . PHP_EOL . print_r($this->errorInfo, true);
  48. }
  49. }