1
0
mirror of synced 2025-01-07 09:37:11 +03:00
This commit is contained in:
zYne 2006-10-08 19:10:21 +00:00
parent 966450d454
commit cba61cb346
3 changed files with 63 additions and 14 deletions

View File

@ -601,7 +601,12 @@ class Doctrine_Query extends Doctrine_Hydrate implements Countable {
* @return array * @return array
*/ */
public static function sqlExplode($str,$d = " ",$e1 = '(',$e2 = ')') { public static function sqlExplode($str,$d = " ",$e1 = '(',$e2 = ')') {
if(is_array($d)) {
$str = preg_split('/('.implode('|', $d).')/', $str);
$d = stripslashes($d[0]);
} else
$str = explode("$d",$str); $str = explode("$d",$str);
$i = 0; $i = 0;
$term = array(); $term = array();
foreach($str as $key => $val) { foreach($str as $key => $val) {

View File

@ -12,17 +12,20 @@ class Doctrine_Query_Where extends Doctrine_Query_Condition {
public function load($where) { public function load($where) {
$e = Doctrine_Query::sqlExplode($where); $e = Doctrine_Query::sqlExplode($where);
if(count($e) < 3) {
$e = Doctrine_Query::sqlExplode($where, array('=', '<', '>', '!='));
}
$r = array_shift($e); $r = array_shift($e);
$a = explode(".",$r); $a = explode(".",$r);
if(count($a) > 1) { if(count($a) > 1) {
$field = array_pop($a); $field = array_pop($a);
$count = count($e); $count = count($e);
$slice = array_slice($e, 0, ($count - 1));
$operator = implode(' ', $slice);
$slice = array_slice($e, -1, 1); $slice = array_slice($e, -1, 1);
$value = implode('', $slice); $value = implode('', $slice);
$operator = trim(substr($where, strlen($r), -strlen($value)));
$reference = implode(".",$a); $reference = implode(".",$a);
$count = count($a); $count = count($a);
@ -100,6 +103,7 @@ class Doctrine_Query_Where extends Doctrine_Query_Condition {
} }
} }
} }
return $where; return $where;
} }

View File

@ -5,7 +5,7 @@ class Doctrine_Query_Where_TestCase extends Doctrine_UnitTestCase {
$this->tables = array('entity'); $this->tables = array('entity');
parent::prepareTables(); parent::prepareTables();
} }
public function testQueryWithDirectParameterSetting() { public function testDirectParameterSetting() {
$this->connection->clear(); $this->connection->clear();
$user = new User(); $user = new User();
@ -21,9 +21,9 @@ class Doctrine_Query_Where_TestCase extends Doctrine_UnitTestCase {
$this->assertEqual($users->count(), 1); $this->assertEqual($users->count(), 1);
$this->assertEqual($users[0]->name, 'someone'); $this->assertEqual($users[0]->name, 'someone');
} }
public function testQueryWithDirectMultipleParameterSetting() { public function testDirectMultipleParameterSetting() {
$user = new User(); $user = new User();
$user->name = 'someone 2'; $user->name = 'someone.2';
$user->save(); $user->save();
$q = new Doctrine_Query(); $q = new Doctrine_Query();
@ -34,7 +34,47 @@ class Doctrine_Query_Where_TestCase extends Doctrine_UnitTestCase {
$this->assertEqual($users->count(), 2); $this->assertEqual($users->count(), 2);
$this->assertEqual($users[0]->name, 'someone'); $this->assertEqual($users[0]->name, 'someone');
$this->assertEqual($users[1]->name, 'someone 2'); $this->assertEqual($users[1]->name, 'someone.2');
}
public function testOperatorWithNoTrailingSpaces() {
$q = new Doctrine_Query();
$q->from('User(id)')->where("User.name='someone'");
$users = $q->execute();
$this->assertEqual($users->count(), 1);
$this->assertEqual($q->getQuery(), "SELECT entity.id AS entity__id FROM entity WHERE entity.name = 'someone' AND (entity.type = 0)");
}
public function testOperatorWithNoTrailingSpaces2() {
$q = new Doctrine_Query();
$q->from('User(id)')->where("User.name='foo.bar'");
$users = $q->execute();
$this->assertEqual($users->count(), 0);
$this->assertEqual($q->getQuery(), "SELECT entity.id AS entity__id FROM entity WHERE entity.name = 'foo.bar' AND (entity.type = 0)");
}
public function testOperatorWithSingleTrailingSpace() {
$q = new Doctrine_Query();
$q->from('User(id)')->where("User.name= 'foo.bar'");
$users = $q->execute();
$this->assertEqual($users->count(), 0);
$this->assertEqual($q->getQuery(), "SELECT entity.id AS entity__id FROM entity WHERE entity.name = 'foo.bar' AND (entity.type = 0)");
}
public function testOperatorWithSingleTrailingSpace2() {
$q = new Doctrine_Query();
$q->from('User(id)')->where("User.name ='foo.bar'");
$users = $q->execute();
$this->assertEqual($users->count(), 0);
$this->assertEqual($q->getQuery(), "SELECT entity.id AS entity__id FROM entity WHERE entity.name = 'foo.bar' AND (entity.type = 0)");
} }
} }
?> ?>