PDO.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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\mssql;
  8. /**
  9. * This is an extension of the default PDO class of MSSQL and DBLIB drivers.
  10. * It provides workarounds for improperly implemented functionalities of the MSSQL and DBLIB drivers.
  11. *
  12. * @author Timur Ruziev <resurtm@gmail.com>
  13. * @since 2.0
  14. */
  15. class PDO extends \PDO
  16. {
  17. /**
  18. * Returns value of the last inserted ID.
  19. * @param string|null $sequence the sequence name. Defaults to null.
  20. * @return int last inserted ID value.
  21. */
  22. #[\ReturnTypeWillChange]
  23. public function lastInsertId($sequence = null)
  24. {
  25. return $this->query('SELECT CAST(COALESCE(SCOPE_IDENTITY(), @@IDENTITY) AS bigint)')->fetchColumn();
  26. }
  27. /**
  28. * Starts a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
  29. * natively support transactions.
  30. * @return bool the result of a transaction start.
  31. */
  32. #[\ReturnTypeWillChange]
  33. public function beginTransaction()
  34. {
  35. $this->exec('BEGIN TRANSACTION');
  36. return true;
  37. }
  38. /**
  39. * Commits a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
  40. * natively support transactions.
  41. * @return bool the result of a transaction commit.
  42. */
  43. #[\ReturnTypeWillChange]
  44. public function commit()
  45. {
  46. $this->exec('COMMIT TRANSACTION');
  47. return true;
  48. }
  49. /**
  50. * Rollbacks a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
  51. * natively support transactions.
  52. * @return bool the result of a transaction roll back.
  53. */
  54. #[\ReturnTypeWillChange]
  55. public function rollBack()
  56. {
  57. $this->exec('ROLLBACK TRANSACTION');
  58. return true;
  59. }
  60. /**
  61. * Retrieve a database connection attribute.
  62. *
  63. * It is necessary to override PDO's method as some MSSQL PDO driver (e.g. dblib) does not
  64. * support getting attributes.
  65. * @param int $attribute One of the PDO::ATTR_* constants.
  66. * @return mixed A successful call returns the value of the requested PDO attribute.
  67. * An unsuccessful call returns null.
  68. */
  69. #[\ReturnTypeWillChange]
  70. public function getAttribute($attribute)
  71. {
  72. try {
  73. return parent::getAttribute($attribute);
  74. } catch (\PDOException $e) {
  75. switch ($attribute) {
  76. case self::ATTR_SERVER_VERSION:
  77. return $this->query("SELECT CAST(SERVERPROPERTY('productversion') AS VARCHAR)")->fetchColumn();
  78. default:
  79. throw $e;
  80. }
  81. }
  82. }
  83. }