mirror of
				https://github.com/dg/dibi.git
				synced 2025-10-26 19:21:43 +01:00 
			
		
		
		
	Correct limit and offset for Firebird Driver (#221)
SELECT [FIRST (<int-expr>)] [SKIP (<int-expr>)] <columns> FROM ...
This commit is contained in:
		| @@ -333,9 +333,9 @@ class FirebirdDriver implements Dibi\Driver, Dibi\ResultDriver, Dibi\Reflector | |||||||
| 	 */ | 	 */ | ||||||
| 	public function applyLimit(& $sql, $limit, $offset) | 	public function applyLimit(& $sql, $limit, $offset) | ||||||
| 	{ | 	{ | ||||||
| 		if ($limit >= 0 && $offset > 0) { | 		if ($limit > 0 || $offset > 0) { | ||||||
| 			// see http://scott.yang.id.au/2004/01/limit-in-select-statements-in-firebird/ | 			// http://www.firebirdsql.org/refdocs/langrefupd20-select.html | ||||||
| 			$sql = 'SELECT FIRST ' . (int) $limit . ($offset > 0 ? ' SKIP ' . (int) $offset : '') . ' * FROM (' . $sql . ')'; | 			$sql = 'SELECT ' . ($limit > 0 ? 'FIRST ' . (int) $limit : '') . ($offset > 0 ? ' SKIP ' . (int) $offset : '') . ' * FROM (' . $sql . ')'; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user