array( 'SET', 3 ), '_END_OPTIONS' => array( '_END_OPTIONS', 1 ) ); /** * Possible exceptions in SET statment. * * @var array */ public static $OPTIONS = array( 'CHARSET' => array( 3, 'var', ), 'CHARACTER SET' => array( 3, 'var', ), 'NAMES' => array( 3, 'var', ), 'PASSWORD' => array( 3, 'expr', ), 'SESSION' => 3, 'GLOBAL' => 3, 'PERSIST' => 3, 'PERSIST_ONLY' => 3, '@@SESSION' => 3, '@@GLOBAL' => 3, '@@PERSIST' => 3, '@@PERSIST_ONLY' => 3, ); public static $END_OPTIONS = array( 'COLLATE' => array( 1, 'var', ), 'DEFAULT' => 1 ); /** * Options used in current statement. * * @var OptionsArray[] */ public $options; /** * The end options of this query. * * @var OptionsArray * * @see static::$END_OPTIONS */ public $end_options; /** * The updated values. * * @var SetOperation[] */ public $set; /** * @return string */ public function build() { $ret = 'SET ' . OptionsArray::build($this->options) . ' ' . SetOperation::build($this->set) . ' ' . OptionsArray::build($this->end_options); return trim($ret); } }