| 12
 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
 
 | <?php
namespace Wikimedia\Rdbms;
/**
 * Raw SQL value to be used in query builders
 *
 * @note This should be used very rarely and NEVER with user input.
 *
 * @newable
 * @since 1.43
 */
class RawSQLValue {
	private string $value = '';
	/**
	 * This should be used very rarely and NEVER with user input.
	 *
	 * Most common usecases is the value in a SET clause of UPDATE,
	 * e.g. for updates like `total_pages = total_pages + 1`:
	 *
	 *   $queryBuilder->set( [ 'total_pages' => new RawSQLValue( 'total_pages + 1' ) ] )
	 *
	 * …or as one side of a comparison in a WHERE condition,
	 * e.g. for conditions like `range_start = range_end`, `range_start != range_end`:
	 *
	 *   $queryBuilder->where( [ 'range_start' => new RawSQLValue( 'range_end' ) ] )
	 *   $queryBuilder->where( $db->expr( 'range_start', '!=', new RawSQLValue( 'range_end' ) ) )
	 *
	 * (When all values are literals, consider whether using RawSQLExpression is more readable.)
	 *
	 * @param string $value Value (SQL fragment)
	 * @param-taint $value exec_sql
	 * @since 1.43
	 */
	public function __construct( string $value ) {
		$this->value = $value;
	}
	/**
	 * @internal to be used by rdbms library only
	 */
	public function toSql(): string {
		return $this->value;
	}
}
 |