aboutsummaryrefslogtreecommitdiff
path: root/engine/classes/WhereQueryComponent.php
blob: 92062de32c8343d9dfaf21618138c187ca4280fd (plain)
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
<?php
/**
 * @class WhereQueryComponent
 * A component of a where query.
 * @see Query
 */
class WhereQueryComponent extends QueryComponent
{
	/**
	 * A where query.
	 *
	 * @param string $left_table The table on the left of the operator
	 * @param string $left_field The left field
	 * @param string $operator The operator eg "=" or "<"
	 * @param string $right_table The table on the right of the operator
	 * @param string $right_field The right field
	 * @param string $link_operator How this where clause links with the previous clause, eg. "and" "or"
	 */
	function __construct($left_table, $left_field, $operator, $right_table, $right_field, $link_operator = "and")
	{
		global $CONFIG;

		$this->link_operator = sanitise_string($link_operator);
		$this->left_table = $CONFIG->dbprefix . sanitise_string($left_table);
		$this->left_field = sanitise_string($left_field);
		$this->operator = sanitise_string($operator);
		$this->right_table = $CONFIG->dbprefix . sanitise_string($right_table);
		$this->right_field = sanitise_string($right_field);
	}

	/**
	 * Return the SQL without the link operator.
	 */
	public function toStringNoLink()
	{
		return "{$this->left_table }.{$this->left_field} {$this->operator} {$this->right_table}.{$this->right_field}";
	}

	function __toString()
	{
		return "{$this->link_operator} " . $this->toStringNoLink();
	}
}