You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.5 KiB
86 lines
2.5 KiB
<?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 integer 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 boolean 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 boolean 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 boolean 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 integer $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 PDO::ATTR_SERVER_VERSION: |
|
return $this->query("SELECT SERVERPROPERTY('productversion')")->fetchColumn(); |
|
default: |
|
throw $e; |
|
} |
|
} |
|
} |
|
}
|
|
|