Foros del Web » Programando para Internet » PHP »

Problema MySQL

Estas en el tema de Problema MySQL en el foro de PHP en Foros del Web. Hola, En mi código de registro utilizo esto para saber si existe el nick que introduce el usuario en la base de datos: Código PHP: ...
  #1 (permalink)  
Antiguo 16/09/2008, 02:24
Avatar de Darth_Carl  
Fecha de Ingreso: mayo-2008
Ubicación: En Foros DWP
Mensajes: 160
Antigüedad: 15 años, 11 meses
Puntos: 8
Problema MySQL

Hola,
En mi código de registro utilizo esto para saber si existe el nick que introduce el usuario en la base de datos:
Código PHP:
<?php
//...
$usuarios=mysql_query("SELECT name FROM users WHERE name='$_POST['nick']'");
if(
$user_ok=mysql_fetch_array($usuarios)) {
//...
?>

Pero al probarlo, me da este error:

Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE, expecting T_STRING or T_VARIABLE or T_NUM_STRING in /var/www/vhosts/forosdwp.com/subdomains/ptc/httpdocs/registro.php on line 12

La línea 12 es $usuarios=mysql_query("SELECT name FROM ptc_users WHERE name='$_POST['nick']'");

¿Que está mal en el código?
__________________
Si te ha servido, un karma POSITIVO es agradecido
NOTA: También se aceptan donaciones a PayPal xD

Última edición por Darth_Carl; 16/09/2008 a las 02:31
  #2 (permalink)  
Antiguo 16/09/2008, 03:05
 
Fecha de Ingreso: septiembre-2003
Mensajes: 96
Antigüedad: 20 años, 7 meses
Puntos: 3
Respuesta: Problema MySQL

El query SQL es lo que está mal, deberías hacer algo así (además, para grandes consultas te será mucho más claro en el futuro) :
Código PHP:
<?php

# construccion de consulta SQL
$sql  "SELECT name ";
$sql .= "FROM users ";
$sql .= "WHERE name = '";
$sql .= mysql_escape_string($_POST['nick']);
$sql .= "';";

# llamada a query
$usuarios mysql_query($sql);

?>
  #3 (permalink)  
Antiguo 16/09/2008, 03:11
Avatar de Legoltaz  
Fecha de Ingreso: agosto-2008
Mensajes: 325
Antigüedad: 15 años, 8 meses
Puntos: 6
Respuesta: Problema MySQL

Código PHP:
$usuarios mysql_query("SELECT name FROM users WHERE name LIKE '$_POST[nick]'"); 
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 13:16.