El error es explicito
Unknown column 'XXX' in 'where clause'.
Eso quiere decir que la columna name es desconocida
Errores de concepto
1. No estas concatenando el usuario
2. Lo que hace IN es resumir esto:
WHERE planeta=tierra OR planeta=marte OR planeta=venus OR planeta=jupiter,...
En esto
WHERE planeta IN(tierra,marte,venus,jupiter,...)
Por lo tanto tendrias que concatenar solo el valor de IN
Código PHP:
Ver original$in = "";
for($k=0;$k<sizeof($usuarios);$k++){ $us = $usuarios[$k]
$in = "'$us',";
}
$in = substr($in,0,-1); //quito la última coma
Como no entiendo realmente que quieres hacer si hacer los updates en el for, o fuera de este, si quieres fuera tendrias que usar IN y usarías el primer código que te dejo, si quieres dentro del for el segundo
De todas formas si quieres usar uno u otro tu update esta totalmente fuera de contexto, estas mezclando ambos conceptos
Código PHP:
Ver original$in = "";
for($k=0;$k<sizeof($usuarios);$k++){ $us = $usuarios[$k]
$in .= "'$us',";
}
$in = substr($in,0,-1); //quito la última coma
$sql = "UPDATE sipbuddies SET ".$sql;
$sql .= " WHERE ";
$sql .= " name='$in'";
Código PHP:
Ver originalfor($i=0; $i<count($usuarios); $i++) {
$sql = "UPDATE sipbuddies SET ".$sql;
$sql .= " WHERE ";
$sql .= " name='".$usuarios[$i]."'";
}
Te recomiendo usar rtrim primero en $sql y no en la concatenacion:
$sql = "UPDATE sipbuddies SET ".rtrim($sql, ',');
Otra recomendacion no concatenes cosas que no son necesarias
$sql .= " WHERE ";
$sql .= " name='".$usuarios[$i]."'";
$sql .= " WHERE name='".$usuarios[$i]."'";
Otra recomendacion, usa POO para no tener que declarar la conexion en el parametro de mysqli_query, y ademas la funcion mysqli_query en POO es mas corta
$db->query($sql);
Eso.