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