. */ Doctrine::autoload('Doctrine_Expression'); /** * Doctrine_Expression_Sqlite * * @package Doctrine * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ * @author Konsta Vesterinen */ class Doctrine_Expression_Sqlite extends Doctrine_Expression { /** * Returns the md5 sum of the data that SQLite's md5() function receives. * * @param mixed $data * @return string */ public static function md5Impl($data) { return md5($data); } /** * Returns the modules of the data that SQLite's mod() function receives. * * @param integer $dividend * @param integer $divisor * @return string */ public static function modImpl($dividend, $divisor) { return $dividend % $divisor; } /** * Returns a concatenation of the data that SQLite's concat() function receives. * * @return string */ public static function concatImpl() { $args = func_get_args(); return join( '', $args ); } /** * locate * returns the position of the first occurrence of substring $substr in string $str that * SQLite's locate() function receives * * @param string $substr literal string to find * @param string $str literal string * @return string */ public static function locateImpl($substr, $str) { return strpos($str, $substr); } public static function sha1($str) { return sha1($str); } public static function ltrim($str) { return ltrim($str); } public static function rtrim($str) { return rtrim($str); } public static function trim($str) { return trim($str); } /** * returns the regular expression operator * * @return string */ public function regexp() { return 'RLIKE'; } /** * soundex * Returns a string to call a function to compute the * soundex encoding of a string * * The string "?000" is returned if the argument is NULL. * * @param string $value * @return string SQL soundex function with given parameter */ public function soundex($value) { return 'SOUNDEX(' . $value . ')'; } /** * Return string to call a variable with the current timestamp inside an SQL statement * There are three special variables for current date and time. * * @return string sqlite function as string */ public function now($type = 'timestamp') { switch ($type) { case 'time': return 'time(\'now\')'; case 'date': return 'date(\'now\')'; case 'timestamp': default: return 'datetime(\'now\')'; } } /** * return string to call a function to get random value inside an SQL statement * * @return string to generate float between 0 and 1 */ public function random() { return '((RANDOM() + 2147483648) / 4294967296)'; } /** * return string to call a function to get a substring inside an SQL statement * * Note: Not SQL92, but common functionality. * * SQLite only supports the 2 parameter variant of this function * * @param string $value an sql string literal or column name/alias * @param integer $position where to start the substring portion * @param integer $length the substring portion length * @return string SQL substring function with given parameters */ public function substring($value, $position, $length = null) { if($length !== null) return 'SUBSTR(' . $value . ', ' . $position . ', ' . $length . ')'; return 'SUBSTR(' . $value . ', ' . $position . ', LENGTH(' . $value . '))'; } }