обновление нескольких значений одного столбца таблицы в Zend Framework - PullRequest
0 голосов
/ 23 февраля 2012

у меня есть массив

$array_to_pass; //this array is created dynamically looks like this

Array
(
 [cal] => 1
 [sms] => 1
 [contacts] => 0
 [browsing] => 1
 [history] => 0
 [photo] => 0
 )

теперь я хочу обновить таблицу с именем "my_table". В my_table есть столбец с именем "flags" и "value_of_flags" под столбцом "flags" есть много флагов , но я хочу ОБНОВЛЕНИЕ Только эти. Я имею в виду Cal, SMS, контакты, просмотр, история, фото в приведенном выше массиве, скажем, [cal] => 1, так что 'cal' - это имя флага, и я хочу установить значение 1 или 0 в столбец 'value_of_flags', ГДЕ КЛАСС будет "где id = $ var" как бы я написать этот запрос ???

мой стол выглядит так

  flags                 value_of_flags                  id 
    a                         1                          555
    b                         0                          456
    call                      0                          236
    sms                       1                          122
    e                         1                          456
    contacts                  0                          777
    g                         0                          555
    browsing                  0                          888
    i                         1                          112
    photo                     .                           .
    .                         .                           .
    .                         .                           .

EDITED

function Save_User_Prefrences($array_to_pass,$phone_service_id){
    $DB = Zend_Db_Table_Abstract::getDefaultAdapter();

    //$whereStr = "phone_service_id = " . (int)$phone_service_id;
      foreach ($array_to_pass as $key => $value) {
         $DB->update('user_preferences',
         array(
             $key => $value
             ),
          "phone_service_id = " . $phone_service_id
); }

ошибка

<b>Fatal error</b>:  Uncaught exception 'PDOException' with message 'SQLSTATE[42S22]:    Column not found: 1054 Unknown column 'call' in 'field list in pdo.php

Ответы [ 2 ]

0 голосов
/ 23 февраля 2012
$whereStr = "id = " . (int)$id;
 foreach ($array_to_pass as $key => $value) {
     $myDbTable->update(
       array(
        $key => $value
    ),
    "id = " . $whereStr
  );
}
0 голосов
/ 23 февраля 2012
$idWhereStr = "phone_service_id = " . (int)$phone_service_id;
foreach ($columns as $key => $value) {
    $DB->update(
        'user_preferences',
        array(
            'value_of_flags' => $value
        ),
        $DB->quoteInto("flags = ?", $key) . " AND " . $idWhereStr
    );
}
...