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