Browse Source

Added support for specifying columns when paginating.

Taylor Otwell 13 years ago
parent
commit
989ba6743b
1 changed files with 15 additions and 1 deletions
  1. 15 1
      system/db/query.php

+ 15 - 1
system/db/query.php

@@ -458,12 +458,26 @@ class Query {
 	 * Get paginated query results.
 	 *
 	 * @param  int        $per_page
+	 * @param  array      $columns
 	 * @return Paginator
 	 */
-	public function paginate($per_page)
+	public function paginate($per_page, $columns = array('*'))
 	{
+		$select = $this->select;
+
 		$total = $this->count();
 
+		// Every query clears the SELECT clause, so we store the contents of the clause
+		// before executing the count query and then put the contents back in afterwards.
+		if ( ! is_null($select))
+		{
+			$this->select = $select;
+		}
+		else
+		{
+			$this->select($columns);
+		}
+
 		$current_page = \System\Paginator::page($total, $per_page);
 
 		return \System\Paginator::make($this->for_page($current_page, $per_page)->get(), $total, $per_page);