Foros del Web » Programando para Internet » PHP »

Consulta foreach anidado, no logro hacerlo funcionar

Estas en el tema de Consulta foreach anidado, no logro hacerlo funcionar en el foro de PHP en Foros del Web. Estoy intentando traer de una base de datos los registros correspondientes a 'medida' y 'precio'. Base de Datos: En razon de estos arrays: Código: array(5) ...
  #1 (permalink)  
Antiguo 01/06/2020, 11:18
Avatar de cuatrosoles  
Fecha de Ingreso: junio-2009
Mensajes: 66
Antigüedad: 15 años, 5 meses
Puntos: 1
Consulta foreach anidado, no logro hacerlo funcionar

Estoy intentando traer de una base de datos los registros correspondientes a 'medida' y 'precio'.
Base de Datos:



En razon de estos arrays:

Código:
array(5) {
  ["accion"]=>
  string(9) "act_plato"
  ["categoria_id"]=>
  string(3) "142"
  ["id"]=>
  string(3) "640"
  ["index"]=>
  string(1) "1"
  ["datos"]=>
  array(1) {
    ["plt"]=>
    array(1) {
      [2]=>
      array(6) {
        ["es"]=>
        array(2) {
          ["nombre"]=>
          string(10) "Plato Tres"
          ["texto"]=>
          string(22) "Descripcion plato tres"
        }
        ["en"]=>
        array(2) {
          ["nombre"]=>
          string(0) ""
          ["texto"]=>
          string(0) ""
        }
        ["precios"]=>
        array(2) {
          [0]=>
          array(2) {
            ["medida"]=>
            string(14) "Porcion Grande"
            ["precio"]=>
            string(2) "25"
          }
          [1]=>
          array(2) {
            ["medida"]=>
            string(13) "Porcion Chica"
            ["precio"]=>
            string(2) "18"
          }
        }
      }
    }
  }
}

$arrPrecios = $platos[$index + 1]['precios'];

$cp = $dao->query("select * from carta_platos where id=$id")->fetch();
$id_plato = $cp['id'];
$pp = $dao->query("select * from carta_precios where carta_platos_id=$id_plato")->fetchAll();

foreach ($pp as $ppid) {

      $precioId = $ppid['id'];
      //echo $precioId."\n";

      foreach ($arrPrecios as $values) { 
            //$precioId = $value['id'];
            $precioMedida = $values['medida'];
            $precioPrecio = $values['precio'];

            $sqlPrecio = "UPDATE carta_precios SET medida='$precioMedida',precio='$precioPrecio',carta_platos_id='$id_plato',estado='0' WHERE id='$precioId' AND carta_platos_id='$id_plato'";

            $dao->exec($sqlPrecio);
            }
        }
Cada vez que actualizo el precio o la medida de un plato me guarda solo el ultimo en todos los registros de la base de datos correspondiente a ese plato. Por ejemplo, si yo guardara esta edicion, en la base de datos se actualizaria la tabla "carta_precios" con id 1 y 2 con el mismo registro ("Porcion Chica", "15"). Se entiende?
Gracias por su ayuda desde ya.
  #2 (permalink)  
Antiguo 14/06/2020, 03:33
Avatar de dashtrash
Colaborador
 
Fecha de Ingreso: abril-2007
Ubicación: Ni en Sevilla,ni en Sanlúcar..qué más da..
Mensajes: 927
Antigüedad: 17 años, 7 meses
Puntos: 270
Respuesta: Consulta foreach anidado, no logro hacerlo funcionar

Mirando el listado que tienes, hay 2 ids: uno, llamado simplemente "id", es único.
Otro, llamado "carta_platos_id", no lo es.

En el var_dump que muestras, hay un campo "id", cuyo valor es 640, lo que corresponde a un "carta_platos_id" del listado. Es ese id el que estás usando en el update, y es por eso que te está actualizando más de una fila.

Etiquetas: foreach, mysql
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 15:14.