2011-01-26 22 views
5

que tienen que actualizar varias columnas en Symfony, pero en ninguna parte puedo encontrar la solución ... Por lo tanto, me gustaría hacerlo de esta manera:Actualizar varias columnas con la doctrina de Symfony

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

OK, eso funciona, pero tengo que hacerlo con varias columnas. Probé algo como esto, pero no funciona:

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

Respuesta

14

Probar:

$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! ¡Eso funciona! ¡Muchas gracias! :) – kungfucsiga

+0

Limpio: no se ha visto antes. +1 :) – richsage

+0

¿Cómo sabe jQuery que John es un nombre literal, no de una columna (lo estoy preguntando porque hay ejemplos como -> set ('cantidad', 'cantidad + 200'). Y tengo problemas en estas líneas ... –

1

Trate

$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 
     } 
    } 

} 

}

Cuestiones relacionadas