2011-01-26 5 views
5

devo aggiornare più colonne in Symfony, ma posso in nessun luogo trovare la soluzione ... Quindi, mi piacerebbe farlo in questo modo:aggiornamento più colonne con la dottrina in Symfony

$q = Doctrine_Query::create() 
    ->update('WebusersTable q') 
    ->set('q.login_name','?','John') 
    ->where('q.webuser_id=?',1) 
    ->execute(); 

OK, funziona, ma devo farlo con diverse colonne. Ho provato qualcosa di simile, ma non funziona:

$q = Doctrine_Query::create() 
    ->update('WebusersTable q') 
    ->set('q.login_name,q.name','?','kaka,pisa') 
    ->where('q.webuser_id=?',1) 
    ->execute(); 

risposta

14

Prova:

$q = Doctrine_Query::create() 
    ->update('WebusersTable q') 
    ->set('q.login_name', 'John') 
    ->set('q.name', 'Another value') 
    ->where('q.webuser_id=?',1) 
    ->execute(); 
+0

Wow! Che funzioni! Grazie mille! :) – kungfucsiga

+0

Neat - non visto che usato prima. +1 :) – richsage

+0

In che modo jQuery sa che John è un nome letterale, non un nome (lo chiedo perché ci sono esempi come -> set ('amount', 'amount + 200'). E ho problemi lungo queste linee ... –

1

Prova

$q = Doctrine_Query::create() 
->update('WebusersTable q') 
->set(array('q.login_name' => 'John', 
      'q.name' => 'Another value')) 
->where('q.webuser_id=?',1) 
->execute(); 
0
class contentActions extends sfActions { 

const TABLE_NAME_ARTICLE = 'article'; 

/** 
* Executes index action 
* 
* @param sfRequest $request A request object 
*/ 
public function executeIndex(sfWebRequest $request) { 


    // Get id from $_GET 
    $id = $request->hasParameter('id') ? $request->getParameter('id') : $request->getPostParameter(self::TABLE_NAME_ARTICLE . '[id]'); 

    // Create model active row by id 
    $modelActiveRow = Doctrine::getTable(self::TABLE_NAME_ARTICLE)->find($id); 

    // Verify existence article 
    $this->forward404Unless($modelActiveRow); 

    // Get form name 
    $formName = self::TABLE_NAME_ARTICLE . 'Form'; 

    // Create article form object. Use model article (load data). 
    $this->form = new $formName($modelActiveRow); 

    if ($request->isMethod('post')) { 

     $postData = $request->getParameter(self::TABLE_NAME_ARTICLE); 
     $this->form->bind($postData); 

     if ($this->form->isValid()) { 
      $this->form->save(); 
      $this->getUser()->setFlash('notice', 'Changes were successfully saved.'); 
      // redirect 
     } 
    } 

} 

}