1
0
mirror of synced 2025-01-07 09:37:11 +03:00

[2.0] Some fixes in Expr. More documentation added.

This commit is contained in:
guilhermeblanco 2009-08-14 20:46:43 +00:00
parent abc853ec48
commit c81affb9f7
5 changed files with 61 additions and 18 deletions

View File

@ -48,6 +48,11 @@ class Expr
return new Expr\Select(func_get_args()); return new Expr\Select(func_get_args());
} }
public static function from($from, $alias = null)
{
return new Expr\From($from, $alias);
}
public static function orderBy($sort = null, $order = null) public static function orderBy($sort = null, $order = null)
{ {
return new Expr\OrderBy($sort, $order); return new Expr\OrderBy($sort, $order);
@ -113,7 +118,7 @@ class Expr
return new Expr\Func('COUNT', array($x)); return new Expr\Func('COUNT', array($x));
} }
public static function countDistinct() public static function countDistinct($x)
{ {
return 'COUNT(DISTINCT ' . implode(', ', func_get_args()) . ')'; return 'COUNT(DISTINCT ' . implode(', ', func_get_args()) . ')';
} }
@ -183,14 +188,9 @@ class Expr
return new Expr\Func($x . ' NOT IN', (array) $y); return new Expr\Func($x . ' NOT IN', (array) $y);
} }
public static function notEqual($x, $y)
{
return new Expr\Comparison($x, '!=', $y);
}
public static function like($x, $y) public static function like($x, $y)
{ {
return new Expr\Math($x, 'LIKE', $y); return new Expr\Comparison($x, 'LIKE', $y);
} }
public static function concat($x, $y) public static function concat($x, $y)
@ -232,8 +232,8 @@ class Expr
return new Expr\Func('BETWEEN', array($val, $x, $y)); return new Expr\Func('BETWEEN', array($val, $x, $y));
} }
public static function trim() public static function trim($x)
{ {
return new Expr\Func('TRIM', func_get_args()); return new Expr\Func('TRIM', $x);
} }
} }

View File

@ -0,0 +1,48 @@
<?php
/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see
* <http://www.doctrine-project.org>.
*/
namespace Doctrine\ORM\Query\Expr;
/**
* Expression class for DQL from
*
* @author Jonathan H. Wage <jonwage@gmail.com>
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
* @link http://www.phpdoctrine.org
* @since 2.0
* @version $Revision$
*/
class From
{
private $_from;
private $_alias;
public function __construct($from, $alias = null)
{
$this->_from = $from;
$this->_alias = $alias;
}
public function __toString()
{
return $this->_from . ($this->_alias ? ' ' . $this->_alias : '');
}
}

View File

@ -38,7 +38,7 @@ class Func
public function __construct($name, $arguments) public function __construct($name, $arguments)
{ {
$this->_name = $name; $this->_name = $name;
$this->_arguments = $arguments; $this->_arguments = (array) $arguments;
} }
public function __toString() public function __toString()

View File

@ -252,9 +252,9 @@ class QueryBuilder
return $this->add('set', Expr::eq($key, $value), true); return $this->add('set', Expr::eq($key, $value), true);
} }
public function from($from, $alias) public function from($from, $alias = null)
{ {
return $this->add('from', $from . ' ' . $alias, true); return $this->add('from', Expr::from($from, $alias), true);
} }
public function innerJoin($parentAlias, $join, $alias, $condition = null) public function innerJoin($parentAlias, $join, $alias, $condition = null)

View File

@ -140,11 +140,6 @@ class ExprTest extends \Doctrine\Tests\OrmTestCase
$this->assertEquals('1 = 1', (string) Expr::eq(1, 1)); $this->assertEquals('1 = 1', (string) Expr::eq(1, 1));
} }
public function testNotEqualExpr()
{
$this->assertEquals('1 != 2', (string) Expr::notEqual(1, 2));
}
public function testLikeExpr() public function testLikeExpr()
{ {
$this->assertEquals('a.description LIKE :description', (string) Expr::like('a.description', ':description')); $this->assertEquals('a.description LIKE :description', (string) Expr::like('a.description', ':description'));