join.php 1.15 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
<?php namespace Laravel\Database\Query;

class Join {

	/**
	 * The type of join being performed.
	 *
	 * @var string
	 */
	public $type;

	/**
	 * The table the join clause is joining to.
	 *
	 * @var string
	 */
	public $table;

	/**
	 * The ON clauses for the join.
	 *
	 * @var array
	 */
	public $clauses = array();

	/**
	 * Create a new query join instance.
	 *
	 * @param  string  $type
	 * @param  string  $table
	 * @return void
	 */
	public function __construct($type, $table)
	{
		$this->type = $type;
		$this->table = $table;
	}

	/**
	 * Add an ON clause to the join.
	 *
	 * @param  string  $column1
	 * @param  string  $operator
	 * @param  string  $column2
	 * @param  string  $connector
	 * @return Join
	 */
	public function on($column1, $operator, $column2, $connector = 'AND')
	{
		$this->clauses[] = compact('column1', 'operator', 'column2', 'connector');

		return $this;
	}

	/**
	 * Add an OR ON clause to the join.
	 *
	 * @param  string  $column1
	 * @param  string  $operator
	 * @param  string  $column2
	 * @return Join
	 */
	public function or_on($column1, $operator, $column2)
	{
		return $this->on($column1, $operator, $column2, 'OR');
	}

}