Foros del Web » Programando para Internet » PHP »

problema con str_replace y array de mas de 10 posiciones...

Estas en el tema de problema con str_replace y array de mas de 10 posiciones... en el foro de PHP en Foros del Web. Hola, resulta que estoy teniendo un problema muy extraño con la funcion str_replace, ya que tengo x ejemplo esta cadena: $query = "INSERT INTO tabla ...
  #1 (permalink)  
Antiguo 22/01/2005, 09:10
 
Fecha de Ingreso: febrero-2002
Mensajes: 57
Antigüedad: 22 años, 9 meses
Puntos: 0
problema con str_replace y array de mas de 10 posiciones...

Hola, resulta que estoy teniendo un problema muy extraño con la funcion str_replace, ya que tengo x ejemplo esta cadena:

$query = "INSERT INTO tabla (campo1, campo2, campo3, campo4, campo5, campo6, campo7, campo8, campo9, campo10, campo11, campo12, campo13, campo14) VALUES (:1, :2, :3, :4, :5, :6, :7, :8, :9, :10, :11, :12, :13, :14)"

y este vector:

$binds[1]='valor1'
$binds[2]='valor2'
etc...
$binds[14]='valor14'

ejecuto este bucle:

foreach ($this->binds as $ph => $pv) {
$query = str_replace(":$ph", "'".mysql_escape_string($pv)."'", $query);
}

y si la longitud del vector $binds es menor de 10 funciona perfecto, me da como resultado un query correcto, pero si este es mayor da algo así:

INSERT INTO tabla (campo1, campo2, campo3, campo4, campo5, campo6, campo7, campo8, campo9, campo10, campo11, campo12, campo13, campo14) VALUES ('valor1', 'valor2', 'valor3', 'valor4', 'valor5', 'valor6', 'valor7', 'valor8', 'valor9', 'valor1'0, 'valor1'1, 'valor1'2, 'valor1'3, 'valor1'4)

Querria saber porque pasa esto tan raro, y como lo puedo solucionar...

Saludos y gracias
  #2 (permalink)  
Antiguo 22/01/2005, 10:53
 
Fecha de Ingreso: febrero-2002
Mensajes: 57
Antigüedad: 22 años, 9 meses
Puntos: 0
Resuelto...

Hola:

Ya he resuelto el problema...

lo que pasaba era que cuando hacia el replace con ":1" por ejemplo, tambien lo hacia con una parte del ":10" y por eso fallaba, lo he resuelto cambiando el foreach por:

for( $i=$cnt+1; $i>0; $i-- ){
$query = str_replace(":$i", "'".mysql_escape_string($this->binds[$i])."'", $query);
}
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 21:12.