Browse Source

added decrement method to query builder.

Taylor Otwell 13 years ago
parent
commit
9bf978abcd
1 changed files with 26 additions and 1 deletions
  1. 26 1
      laravel/database/query.php

+ 26 - 1
laravel/database/query.php

@@ -590,7 +590,32 @@ class Query {
 	 */
 	 */
 	public function increment($column, $amount = 1)
 	public function increment($column, $amount = 1)
 	{
 	{
-		return $this->update(array($column => Manager::raw($this->grammar->wrap($column).' + '.$amount)));
+		return $this->adjust($column, $amount, ' + ');
+	}
+
+	/**
+	 * Decrement the value of a column by a given amount.
+	 *
+	 * @param  string  $column
+	 * @param  int     $amount
+	 * @return int
+	 */
+	public function decrement($column, $amount = 1)
+	{
+		return $this->adjust($column, $amount, ' - ');
+	}
+
+	/**
+	 * Adjust the value of a column up or down by a given amount.
+	 *
+	 * @param  string  $column
+	 * @param  int     $amount
+	 * @param  string  $operator
+	 * @return int
+	 */
+	protected function adjust($column, $amount, $operator)
+	{
+		return $this->update(array($column => Manager::raw($this->grammar->wrap($column).$operator.$amount)));
 	}
 	}
 
 
 	/**
 	/**