<?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;
	}
}