當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Doctrine_Query::query方法代碼示例

本文整理匯總了PHP中Doctrine_Query::query方法的典型用法代碼示例。如果您正苦於以下問題:PHP Doctrine_Query::query方法的具體用法?PHP Doctrine_Query::query怎麽用?PHP Doctrine_Query::query使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Doctrine_Query的用法示例。


在下文中一共展示了Doctrine_Query::query方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: testIterator

    public function testIterator() {
        $graph = new Doctrine_Query($this->connection);
        $entities = $graph->query("FROM Entity");
        $i = 0;
        foreach($entities as $entity) {
            $this->assertEqual(gettype($entity->name),"string");
            $i++;
        }
        $this->assertTrue($i == $entities->count());
        
        $user = $graph->query("FROM User");
        foreach($user[1]->Group as $group) {
            $this->assertTrue(is_string($group->name));
        }     
        
        $user = new User();
        $user->name = "tester";
        
        $user->Address[0]->address = "street 1";
        $user->Address[1]->address = "street 2";
        
        $this->assertEqual($user->name, "tester");
        $this->assertEqual($user->Address[0]->address, "street 1");
        $this->assertEqual($user->Address[1]->address, "street 2");

        foreach($user->Address as $address) {
            $a[] = $address->address;
        }
        $this->assertEqual($a, array("street 1", "street 2"));   

        $user->save();
        
        $user = $user->getTable()->find($user->id);
        $this->assertEqual($user->name, "tester");
        $this->assertEqual($user->Address[0]->address, "street 1");
        $this->assertEqual($user->Address[1]->address, "street 2");
        
        $user = $user->getTable()->find($user->id);
        $a = array();
        foreach($user->Address as $address) {
            $a[] = $address->address;
        }
        $this->assertEqual($a, array("street 1", "street 2"));                                    


        $user = $graph->query("FROM User");
    }
開發者ID:prismhdd,項目名稱:victorioussecret,代碼行數:47,代碼來源:BatchIteratorTestCase.php

示例2: execute

 public function execute()
 {
     Doctrine::loadModels($this->getArgument('models_path'));
     $dql = $this->getArgument('dql_query');
     $query = new Doctrine_Query();
     $this->notify('executing: "' . $dql . '"');
     $results = $query->query($dql);
     $this->printResults($results);
 }
開發者ID:kirvin,項目名稱:the-nerdery,代碼行數:9,代碼來源:Dql.php

示例3: execute

 public function execute()
 {
     Doctrine::loadModels($this->getArgument('models_path'));
     $dql = $this->getArgument('dql_query');
     $query = new Doctrine_Query();
     $params = $this->getArgument('params');
     $params = $params ? explode(',', $params) : array();
     $this->notify('executing: "' . $dql . '" (' . implode(', ', $params) . ')');
     $results = $query->query($dql, $params, Doctrine::HYDRATE_ARRAY);
     $this->_printResults($results);
 }
開發者ID:stelaireri,項目名稱:Hive,代碼行數:11,代碼來源:Dql.php

示例4: findByDql

 /**
  * findByDql
  * finds records with given DQL where clause
  * returns a collection of records
  *
  * @param string $dql               DQL after WHERE clause
  * @param array $params             query parameters
  * @param int $hydrationMode        Doctrine::HYDRATE_ARRAY or Doctrine::HYDRATE_RECORD
  * @return Doctrine_Collection
  */
 public function findByDql($dql, $params = array(), $hydrationMode = null)
 {
     $parser = new Doctrine_Query($this->_conn);
     $component = $this->getComponentName();
     $query = 'FROM ' . $component . ' dctrn_find WHERE ' . $dql;
     return $parser->query($query, $params, $hydrationMode);
 }
開發者ID:mediasadc,項目名稱:alba,代碼行數:17,代碼來源:Table.php

示例5: loadRelated

 /**
  * Load all relationships or the named relationship passed
  *
  * @param mixed $name
  * @return boolean
  */
 public function loadRelated($name = null)
 {
     $list = array();
     $query = new Doctrine_Query($this->_table->getConnection());
     if (!isset($name)) {
         foreach ($this->data as $record) {
             $value = $record->getIncremented();
             if ($value !== null) {
                 $list[] = $value;
             }
         }
         $query->from($this->_table->getComponentName());
         $query->where($this->_table->getComponentName() . '.id IN (' . substr(str_repeat("?, ", count($list)), 0, -2) . ')');
         return $query;
     }
     $rel = $this->_table->getRelation($name);
     if ($rel instanceof Doctrine_Relation_LocalKey || $rel instanceof Doctrine_Relation_ForeignKey) {
         foreach ($this->data as $record) {
             $list[] = $record[$rel->getLocal()];
         }
     } else {
         foreach ($this->data as $record) {
             $value = $record->getIncremented();
             if ($value !== null) {
                 $list[] = $value;
             }
         }
     }
     $dql = $rel->getRelationDql(count($list), 'collection');
     $coll = $query->query($dql, $list);
     $this->populateRelated($name, $coll);
 }
開發者ID:stelaireri,項目名稱:Hive,代碼行數:38,代碼來源:Collection.php

示例6: queryOne

 /**
  * query
  * queries the database using Doctrine Query Language and returns
  * the first record found
  *
  * <code>
  * $user = $conn->queryOne('SELECT u.* FROM User u WHERE u.id = ?', array(1));
  *
  * $user = $conn->queryOne('SELECT u.* FROM User u WHERE u.name LIKE ? AND u.password = ?',
  *         array('someone', 'password')
  *         );
  * </code>
  *
  * @param string $query             DQL query
  * @param array $params             query parameters
  * @see Doctrine_Query
  * @return Doctrine_Record|false    Doctrine_Record object on success,
  *                                  boolean false on failure
  */
 public function queryOne($query, array $params = array())
 {
     $parser = new Doctrine_Query($this);
     $coll = $parser->query($query, $params);
     if (!$coll->contains(0)) {
         return false;
     }
     return $coll[0];
 }
開發者ID:adnanali,項目名稱:munch,代碼行數:28,代碼來源:Connection.php

示例7: testNotEqual

 public function testNotEqual()
 {
     try {
         $query = new Doctrine_Query($this->connection);
         $ret = $query->query("FROM EnumTest WHERE EnumTest.status != 'closed'");
         $this->assertEqual(count($ret), 1);
     } catch (Exception $e) {
         $this->fail();
     }
 }
開發者ID:kaakshay,項目名稱:audience-insight-repository,代碼行數:10,代碼來源:EnumTestCase.php

示例8: testFetchingWithSmartConversion

 public function testFetchingWithSmartConversion()
 {
     $query = new Doctrine_Query($this->connection);
     $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = false');
     $this->assertEqual(count($ret), 1);
     $query = new Doctrine_Query($this->connection);
     $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = true');
     $this->assertEqual(count($ret), 1);
 }
開發者ID:swk,項目名稱:bluebox,代碼行數:9,代碼來源:BooleanTestCase.php

示例9: findBySql

 /**
  * findByDql
  * finds records with given DQL where clause
  * returns a collection of records
  *
  * @param string $dql               DQL after WHERE clause
  * @param array $params             query parameters
  * @return Doctrine_Collection
  */
 public function findBySql($dql, array $params = array())
 {
     $q = new Doctrine_Query($this->conn);
     $users = $q->query('FROM ' . $this->options['name'] . ' WHERE ' . $dql, $params);
     return $users;
 }
開發者ID:snouhaud,項目名稱:camptocamp.org,代碼行數:15,代碼來源:Table.php

示例10: testMultipleOneToManyFetchingWithOrderBy

 public function testMultipleOneToManyFetchingWithOrderBy()
 {
     $query = new Doctrine_Query();
     $users = $query->query("FROM User.Album.Song WHERE User.id IN (4,5) ORDER BY User.Album.Song.title DESC");
 }
開發者ID:swk,項目名稱:bluebox,代碼行數:5,代碼來源:MultiJoinTestCase.php


注:本文中的Doctrine_Query::query方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。