Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] envio de arreglo a base de datos

Estas en el tema de envio de arreglo a base de datos en el foro de PHP en Foros del Web. Hola, buenas tengo una pequeño problema al que le he estado buscando solución de varias maneras y aun no alcanzo a resolver, tengo el siguiente ...
  #1 (permalink)  
Antiguo 15/10/2014, 11:57
Avatar de Shelonix  
Fecha de Ingreso: octubre-2014
Ubicación: Chile
Mensajes: 11
Antigüedad: 9 años, 6 meses
Puntos: 0
Exclamación envio de arreglo a base de datos

Hola, buenas
tengo una pequeño problema al que le he estado buscando solución de varias maneras y aun no alcanzo a resolver,
tengo el siguiente código con el cual capturo algunos checkbox que están seleccionados, el código me devuelve bien los valores que quiero de los checkbox, hasta ahí bien


codigo jquery
Código:
<script type="text/javascript">
   $(function() {
    $('#enviar').click(function() {
        var codigos = new Array();
 
        $("input[@name='listado[]']:checked").each(function() {
            codigos.push($(this).val());
        });
 
		//alert (codigos);
        $.ajax({
            type: 'POST',
            url: 'cotizacion.php',
            data: codigos,
            success: function(data) {
                // Imprimimos la respuesta en el div result
                $('#result').html(data);

            }
        })
    }); 
});

</script>

luego de capturar el arreglo de los checkbox y arrojar un alert (que he anulado volviéndolo un comentario) para verificar que el proceso se ha realizado bien, hice el intento de un código para arrojar ese arreglo a un documento php que más tarde se encargaría de insertar cada valor en la base de datos


codigo php
Código:
<?php
require_once('libs/conexion.php');
$cn=  Conectarse();

$codigo[] = $_POST['codigos'];

echo "arreglo: ",$codigo;

for ($i=0; $i>=$codigo;$i++) {
$query="INSERT INTO cotizacion (codigo, nombre, modelo) SELECT articulos.codigobarra, articulos.nombreproducto, articulos.modelo FROM articulos WHERE articulos.codigobarra = $codigo";
mysql_query($query) or die(mysql_error());
}

?>
la linea de insertar ya verifiqué que funciona bien, solo pido algo de ayuda para que me guíen en que estoy haciendo mal por acá y poder terminar mi pequeño proyecto.
muchas gracias.
  #2 (permalink)  
Antiguo 15/10/2014, 13:33
Avatar de Patriarka  
Fecha de Ingreso: enero-2011
Ubicación: Moreno, Buenos Aires, Argentina
Mensajes: 2.851
Antigüedad: 13 años, 2 meses
Puntos: 288
Respuesta: envio de arreglo a base de datos

Código PHP:
Ver original
  1. <?php
  2. require_once('libs/conexion.php');
  3. $cn=  Conectarse();
  4.  
  5. $codigos = $_POST['codigos']; //ya es un array
  6.  
  7. echo '<pre>';
  8. print_r($codigos);
  9. echo '</pre>';
  10.  
  11. foreach($codigos as $codigo){
  12. $query="INSERT INTO cotizacion (codigo, nombre, modelo) SELECT articulos.codigobarra, articulos.nombreproducto, articulos.modelo FROM articulos WHERE articulos.codigobarra = $codigo";
  13. mysql_query($query) or die(mysql_error());
  14. }
  15.  
  16. ?>
  #3 (permalink)  
Antiguo 16/10/2014, 10:20
Avatar de Shelonix  
Fecha de Ingreso: octubre-2014
Ubicación: Chile
Mensajes: 11
Antigüedad: 9 años, 6 meses
Puntos: 0
Respuesta: envio de arreglo a base de datos

gracias Patriarka, ya logre resolver mi problematica :D
  #4 (permalink)  
Antiguo 16/10/2014, 11:00
Avatar de Patriarka  
Fecha de Ingreso: enero-2011
Ubicación: Moreno, Buenos Aires, Argentina
Mensajes: 2.851
Antigüedad: 13 años, 2 meses
Puntos: 288
Respuesta: envio de arreglo a base de datos

Cita:
Iniciado por Shelonix Ver Mensaje
gracias Patriarka, ya logre resolver mi problematica :D
ok, y como lo hiciste?
usaste mi solucion?

la idea del foro no es solo compartir el problema sino la solucion
  #5 (permalink)  
Antiguo 16/10/2014, 11:07
Avatar de Shelonix  
Fecha de Ingreso: octubre-2014
Ubicación: Chile
Mensajes: 11
Antigüedad: 9 años, 6 meses
Puntos: 0
Respuesta: envio de arreglo a base de datos

sí, lo se, es que antes de postear aquí ya lo había hecho en el foro de javascript, postie aquí porque me dijeron que me ayudaría por acá ya que mi "problema" con el codigo de jquery estaba bien, pero luego respondieron.

[URL="http://www.forosdelweb.com/f13/pasar-arreglo-con-jquery-para-insertar-base-datos-1111145/"]aquí es donde pregunte primero y deje la solucion[/URL]

así es como solucioné el PHP
Código PHP:
Ver original
  1. require_once('libs/conexion.php');
  2. $cn=  Conectarse();
  3.  
  4. $codigos= $_POST['array'];
  5. $total = count($codigos);
  6.  
  7. for ($i = 0; $i < $total; $i++){
  8. $cod= $codigos[$i];
  9. $query="INSERT INTO cotizacion (codigo, nombre, modelo) SELECT articulos.codigobarra, articulos.nombreproducto, articulos.modelo FROM articulos WHERE articulos.codigobarra = $cod";
  10. mysql_query($query) or die(mysql_error());
  11. }
  #6 (permalink)  
Antiguo 16/10/2014, 11:10
Avatar de Patriarka  
Fecha de Ingreso: enero-2011
Ubicación: Moreno, Buenos Aires, Argentina
Mensajes: 2.851
Antigüedad: 13 años, 2 meses
Puntos: 288
Respuesta: envio de arreglo a base de datos

esta bien, pero tratá de usar foreach
  #7 (permalink)  
Antiguo 16/10/2014, 11:21
Avatar de Shelonix  
Fecha de Ingreso: octubre-2014
Ubicación: Chile
Mensajes: 11
Antigüedad: 9 años, 6 meses
Puntos: 0
Respuesta: envio de arreglo a base de datos

no supe como usarlo y entre los arreglos que intente hacer para solucionar, el array solo me leía el primer valor cuando lo mandaba a al base de datos o decía que estaba vacío por eso me quedé con la opción inicial y pensando y pensando encontré esa opción a mi problema.

pero igual gracias, tendré en cuanta tu solución con foreach para otra oportunidad o en caso de querer reemplazar lo que ya tengo.

Etiquetas: arreglo, database, jquery
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:58.