web-dev-qa-db-fra.com

Comment mettre à jour un enregistrement de table de base de données à Zend?

J'utilise SELECT SELECT CELA TOPHOI SOIT FONCTIONNER UN ARRIGE ARRIGE avec succès:

$table = new Bugs();
$select = $table->select();
$select->where('bug_status = ?', 'NEW');
$rows = $table->fetchAll($select);

Mais maintenant je veux mettre à jour le même enregistrement. Par exemple dans SIMPLE MYSQL.

UPDATE TableName Set id='2' WHERE id='1';

Comment exécuter ci-dessus Query à Zend?

Merci

21
Awan
$data = array(
   'field1' => 'value1',
   'field2' => 'value2'
);
$where = $table->getAdapter()->quoteInto('id = ?', $id)

$table = new Table();

$table->update($data, $where);
40
Alex Pliutau

Puisque vous récupérez déjà la ligne que vous voulez changer, il semble plus simple de faire simplement:

$row->id = 2;
$row->save();
11
Tim Lytle

juste au cas où vous voulez vous incrémenter une colonne utilise Zend_DB_Expr par exemple:

$table->update(array('views' => new Zend_Db_Expr('views + 1')),$where);
9
Srinivas R

Pour plus d'une fois l'instruction, utilisez ce qui suit.

$data = array(
    "field1" => "value1",
    "field2" => "value2"
);
$where['id = ?'] = $id;
$where['status = ?'] = $status;

$table = new Table();

$table->update($data, $where);
4
Waqas Bukhary
public function updateCampaign($id, $name, $value){
    $data = array(
        'name' => $name,
        'value' => $value,
    );
    $this->update($data, 'id = ?', $id );
}
2
zendframeworks
   $data = array(
    "field1" => "value1",
    "field2" => "value2"
);

$where = "id = " . $id;

$table = new Table();

$table->update($data, $where);
1
mitch