62 lines
1.6 KiB
62 lines
1.6 KiB
12 years ago
|
<?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 rollback.
|
||
|
*/
|
||
|
public function rollBack()
|
||
|
{
|
||
|
$this->exec('ROLLBACK TRANSACTION');
|
||
|
return true;
|
||
|
}
|
||
|
}
|