Foros del Web » Programando para Internet » PHP »

Me da un error??? text

Estas en el tema de Me da un error??? text en el foro de PHP en Foros del Web. Hola cuando hago una consulta en un capo de texto, solo me admite números, pero si le pongo cualquier letra me da error en la ...
  #1 (permalink)  
Antiguo 28/09/2006, 15:36
 
Fecha de Ingreso: agosto-2006
Mensajes: 12
Antigüedad: 17 años, 8 meses
Puntos: 0
Me da un error??? text

Hola cuando hago una consulta en un capo de texto, solo me admite números, pero si le pongo cualquier letra me da error en la consulta, como puedo hacer o que para que admita numeros y letras.

pagina1.php
<TR><TD>Número de BL:</TD>
<TD><INPUT TYPE="TEXT" NAME="guia2"></TD></TR>

pagina2.php

<?php
$connection = mysql_connect("localhost","root","") or die ("Unable to connect to MySQL server.");
$db = mysql_select_db("silcadb", $connection) or die ("Unable to select database.");
$sql = "SELECT * from tblinventario where referencia=$guia2 ORDER BY movimiento";
$sql_result = mysql_query($sql,$connection) or die ("Ocurrió un error");
$contados =mysql_num_rows($sql_result);
if ($contados <= 0){
echo "No se encontraron registros con el valor solicitado: <b>$guia2</b> \n";
} else {

Siempre me pone el mensaje "Ocurrio un error" necesito que me permita buscar por letras y numeros.

Gracias por los comentarios o ayuda al respecto
  #2 (permalink)  
Antiguo 28/09/2006, 15:56
Avatar de darkasecas  
Fecha de Ingreso: marzo-2005
Ubicación: SantaCata, NL, Mexico
Mensajes: 1.553
Antigüedad: 19 años, 1 mes
Puntos: 77
Código:
.. where referencia='$guia2' ..
-o-
  #3 (permalink)  
Antiguo 28/09/2006, 16:05
 
Fecha de Ingreso: diciembre-2004
Mensajes: 36
Antigüedad: 19 años, 4 meses
Puntos: 1
Hola hroman:

Me parece que tienes que verificar tu sentencia sql, creo que alli está tu error.

Derrepente el campo "referencia" no admita cadenas generalmente se le asigna de tipo "char" o "varchar".

Espero haberme hecho entender.
  #4 (permalink)  
Antiguo 28/09/2006, 16:17
Avatar de cdavid_00  
Fecha de Ingreso: septiembre-2004
Ubicación: La Gran Tenoch
Mensajes: 124
Antigüedad: 19 años, 7 meses
Puntos: 1
Hola, a ver vamos por partes

¿Qué tipo de dato es el campo sobre el que haces tu consulta?

si es varchar tu consulta debería ir asi

Código PHP:
$sql "SELECT * from tblinventario where referencia='$guia2' ORDER BY movimiento"
pero supongo que el campo es numerico, entonces por la diferencia en los tipos de datos te sale el error, me parece que como el dato que llega no es númerico mysql asume que estas tratando de compararlo con otro campo de esa tabla y pues lo mas seguro es que te mande un error, en un caso remoto, algún resultado, pero obviamente de algo que no es lo que deseas hacer.
Puedes usar la funcion cast o convert de Mysql para convertir a numerico, y tambien te recomiendo que uses:

Código PHP:
$sql_result mysql_query($sql,$connection) or die (mysql_error($connection)); 
Para que veas el error que devuelve Mysql
__________________
"Cuanto más grande es el caos, más cerca está la solución"
"Toda ciencia tiene de ciencia, lo que tiene de matemática"

Última edición por cdavid_00; 28/09/2006 a las 16:31
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:59.