| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | 
							- <?php
 
- /**
 
-  * @link http://www.yiiframework.com/
 
-  * @copyright Copyright (c) 2008 Yii Software LLC
 
-  * @license http://www.yiiframework.com/license/
 
-  */
 
- namespace yii\db\mssql;
 
- /**
 
-  * This is an extension of the default PDO class of MSSQL and DBLIB drivers.
 
-  * It provides workarounds for improperly implemented functionalities of the MSSQL and DBLIB drivers.
 
-  *
 
-  * @author Timur Ruziev <resurtm@gmail.com>
 
-  * @since 2.0
 
-  */
 
- class PDO extends \PDO
 
- {
 
-     /**
 
-      * Returns value of the last inserted ID.
 
-      * @param string|null $sequence the sequence name. Defaults to null.
 
-      * @return int last inserted ID value.
 
-      */
 
-     public function lastInsertId($sequence = null)
 
-     {
 
-         return $this->query('SELECT CAST(COALESCE(SCOPE_IDENTITY(), @@IDENTITY) AS bigint)')->fetchColumn();
 
-     }
 
-     /**
 
-      * Starts a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
 
-      * natively support transactions.
 
-      * @return bool the result of a transaction start.
 
-      */
 
-     public function beginTransaction()
 
-     {
 
-         $this->exec('BEGIN TRANSACTION');
 
-         return true;
 
-     }
 
-     /**
 
-      * Commits a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
 
-      * natively support transactions.
 
-      * @return bool the result of a transaction commit.
 
-      */
 
-     public function commit()
 
-     {
 
-         $this->exec('COMMIT TRANSACTION');
 
-         return true;
 
-     }
 
-     /**
 
-      * Rollbacks a transaction. It is necessary to override PDO's method as MSSQL PDO driver does not
 
-      * natively support transactions.
 
-      * @return bool the result of a transaction roll back.
 
-      */
 
-     public function rollBack()
 
-     {
 
-         $this->exec('ROLLBACK TRANSACTION');
 
-         return true;
 
-     }
 
-     /**
 
-      * Retrieve a database connection attribute.
 
-      *
 
-      * It is necessary to override PDO's method as some MSSQL PDO driver (e.g. dblib) does not
 
-      * support getting attributes.
 
-      * @param int $attribute One of the PDO::ATTR_* constants.
 
-      * @return mixed A successful call returns the value of the requested PDO attribute.
 
-      * An unsuccessful call returns null.
 
-      */
 
-     public function getAttribute($attribute)
 
-     {
 
-         try {
 
-             return parent::getAttribute($attribute);
 
-         } catch (\PDOException $e) {
 
-             switch ($attribute) {
 
-                 case self::ATTR_SERVER_VERSION:
 
-                     return $this->query("SELECT CAST(SERVERPROPERTY('productversion') AS VARCHAR)")->fetchColumn();
 
-                 default:
 
-                     throw $e;
 
-             }
 
-         }
 
-     }
 
- }
 
 
  |