Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Problema preparando sentencia sql en php

Estas en el tema de Problema preparando sentencia sql en php en el foro de PHP en Foros del Web. Quiero preparar un select con dos variables pero me sale error de comillas en la sentencia. Código PHP: $query  =  "SELECT codigo, usuario, clave, acceso FROM  tuser WHERE usuario = "'.$user.'" AND clave ="  . $pass  ...
  #1 (permalink)  
Antiguo 09/12/2016, 08:52
Avatar de bandolera  
Fecha de Ingreso: abril-2009
Mensajes: 613
Antigüedad: 15 años
Puntos: 7
Pregunta Problema preparando sentencia sql en php

Quiero preparar un select con dos variables pero me sale error de comillas en la sentencia.
Código PHP:
$query "SELECT codigo, usuario, clave, acceso
FROM  tuser
WHERE usuario = "'.$user.'" AND clave =" 
.$pass 
$user y $pass son varchar.
Acaso es la comilla simple? también lo puse a la inversa y nada.
__________________
Todos somos iguales. NO! a la violencia de género.
  #2 (permalink)  
Antiguo 09/12/2016, 09:34
Avatar de petit89  
Fecha de Ingreso: marzo-2011
Mensajes: 1.135
Antigüedad: 13 años, 1 mes
Puntos: 170
Respuesta: Problema preparando sentencia sql en php

Código PHP:
Ver original
  1. $query = "SELECT codigo, usuario, clave, acceso FROM  tuser WHERE usuario ='".$user."' AND clave =".$pass;
prueba asi
__________________
█ WebHosting / Reseller a bajo costo | Uptime Garantizado | Soporte en Español e Ingles
¿Te sirvió la respuesta? Deja un +1 (Triangulo negro al lado derecho)
  #3 (permalink)  
Antiguo 09/12/2016, 09:45
alvaro_trewhela
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Problema preparando sentencia sql en php

Me sumo a petit falta poner la última comilla y no es necesario concatenar:

$query = "SELECT codigo, usuario, clave, acceso FROM tuser WHERE usuario ='$user' AND clave ='$pass'";
  #4 (permalink)  
Antiguo 09/12/2016, 10:17
Avatar de bandolera  
Fecha de Ingreso: abril-2009
Mensajes: 613
Antigüedad: 15 años
Puntos: 7
Pregunta Respuesta: Problema preparando sentencia sql en php

Gracias chicos por las respuestas. Al final lo modifiqué de esta manera pero me sale error en el primer bindparam()
Código PHP:
function login($user$pass){
$query "SELECT codigo, usuario, clave, acceso FROM tuser WHERE usuario = :usuario_in AND clave = :clave_in";
$BD = new ConexionDB();  //<-- conexión a base de datos PDO
$recordSet $BD->prepare($query);
$recordSet bindParam('usuario_in'$userPDO::PARAM_STR); //<--  Fatal error: Call to undefined function bindParam()
$recordSet bindParam('clave_in'$passPDO::PARAM_STR);
$recordSet->execute();
$usuario = array();
(.....)

__________________
Todos somos iguales. NO! a la violencia de género.
  #5 (permalink)  
Antiguo 09/12/2016, 18:29
 
Fecha de Ingreso: diciembre-2015
Ubicación: México
Mensajes: 280
Antigüedad: 8 años, 5 meses
Puntos: 20
Respuesta: Problema preparando sentencia sql en php

Hola amiga
Debes de asignar en bindParam el mismo nombre que estás usando en tu $query, es decir ":usuario_in" y ":clave_in"
Saludos
  #6 (permalink)  
Antiguo 09/12/2016, 20:23
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problema preparando sentencia sql en php

El error dice que bindParam() no existe, y es verdad: como función no existe.

¿No es un método del objeto $recordSet o sí?
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #7 (permalink)  
Antiguo 10/12/2016, 12:11
Avatar de bandolera  
Fecha de Ingreso: abril-2009
Mensajes: 613
Antigüedad: 15 años
Puntos: 7
De acuerdo Respuesta: Problema preparando sentencia sql en php

Hola chicos. gracias por sus respuestas.
El error era porque yo usaba
Código PHP:
$recordSet bindParam('usuario_in'$userPDO::PARAM_STR); //<--  Fatal error: Call to undefined function bindParam()
$recordSet bindParam('clave_in'$passPDO::PARAM_STR); 
debiendo ser:
Código PHP:
$recordSet->bindParam('usuario_in'$userPDO::PARAM_STR);
$recordSet->bindParam('clave_in'$passPDO::PARAM_STR); 
Según dice el manual:
http://php.net/manual/es/pdostatement.bindparam.php
Gracias. ya funciona.
__________________
Todos somos iguales. NO! a la violencia de género.

Etiquetas: select, sentencia, sql, usuario, variable
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 06:15.