1

我在 php 中创建了一个个人资料页面。该页面包括地址和电话字段,并提示用户插入他们的数据。然后将数据保存在我的名为 profile 的表中。一切正常,但问题是表每次都会更新所有字段。我使用的功能如下:

function update_user_profile($user_id, $update_data_profile){

$result = mysql_query("select user_id from profile where user_id = $user_id limit 1");

if(mysql_num_rows($result) === 1){

    $update = array();

    array_walk($update_data_profile, 'array_sanitize');

      foreach($update_data_profile as $field => $data ){
    $update[]='`' . $field . '` = \'' . $data . '\'';   
      }

mysql_query(" UPDATE `profile` SET " . implode(',  ', $update) . " WHERE `user_id` = $user_id ") or die(mysql_error());

}else{

$user_id = $update_data_profile['user_id'] ;

if(count($update_data_profile)){

  $columns = array();
  $values = array();

foreach($update_data_profile as $field => $data){
    $columns[] = $field;
    $values[] = $data;
} 
}

mysql_query(" INSERT INTO `profile` (" . implode(",", $columns) .") values ('" . implode("','", $values) . "')" ) or die (mysql_error());

}

}

我的问题是,我怎样才能修改这个函数的第一部分,这样如果用户只为某个字段插入数据,这个字段只会被更新,而不是所有的表。例如,假设用户插入了他的电话和地址。下次如果用户再次使用该表格来更新他的个人资料,如果他改变了他的电话,那么只有在表格中要改变的电话字段和包含他的地址的其他字段保持不变。有任何想法吗?谢谢

4

1 回答 1

1

您需要测试$data变量是否为空:

foreach($update_data_profile as $field => $data ){
    if(!empty($data)){
        $update[]='`' . $field . '` = \'' . $data . '\'';
    }
}
if(isset($update) && !empty($update)){
    mysql_query(" UPDATE `profile` SET " . implode(',  ', $update) . " WHERE `user_id` = $user_id ") or die(mysql_error());
}

和往常一样,您应该远离 mysql_* 函数,并使用MySQLiPDO

于 2013-02-15T15:46:05.747 回答