Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Hacer que cada usuario vea solamente los datos registrados por el mismo

Estas en el tema de Hacer que cada usuario vea solamente los datos registrados por el mismo en el foro de PHP en Foros del Web. Hola amigos. Tengo una gran duda y necesito su ayuda. Estoy trabajando en un pequeño proyecto de php donde a través de un formulario cada ...
  #1 (permalink)  
Antiguo 03/11/2013, 13:39
 
Fecha de Ingreso: octubre-2011
Mensajes: 17
Antigüedad: 13 años, 1 mes
Puntos: 0
Hacer que cada usuario vea solamente los datos registrados por el mismo

Hola amigos. Tengo una gran duda y necesito su ayuda. Estoy trabajando en un pequeño proyecto de php donde a través de un formulario cada usuario tiene acceso al sistema. Voy a usar ejemplos para describir mis tablas y mis campos: tengo una tabla usuario para registrar a todos los que tendrán acceso y una tabla producto para registrar datos relacionados a productos, hasta ahora lo que me funciona es que cualquier usuario pueda entrar y pueda registrar a través de un formulario y se guardan los datos en la tabla productos, o sea, una sola base de datos y una sola tabla para que todos los usuarios registren sus productos. Lo que necesito es que a cada usuario solo les muestre los datos que cada uno registró. Actualmente al ingresar al sistema lo que me funciona es que cualquier usuario está viendo todo lo que está registrado en esa tabla productos, y no quiero eso.
Hasta el momento mi código sql para listar los datos de la tabla es el siguiente:
$sql = "select * from tabla where tbl_campo like '".$filtrar_por."%' order by ".$orden;

Este código me funciona para traer todos los registros no importando el usuario que esté realizando la consulta.
Me gustaría saber si para que cada usuario vea solamente lo que el registró necesito relacionar algún campo en las dos tablas o existe otra manera de hacerlo?
Un dato más es que estoy trabajando con $_SESSION para los usuarios.
  #2 (permalink)  
Antiguo 03/11/2013, 13:57
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Sabadell
Mensajes: 4.897
Antigüedad: 16 años, 8 meses
Puntos: 574
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

La unica forma de hacerlo es que al guardar un producto guardes quien lo ha registrado. Es decir debes guardar el id del usuario al mismo timpo que guardas el producto en la tabla productos ... luego la consulta la debes limitar por el usuario actual...


$sql = "select * from tabla where tbl_campo like '".$filtrar_por."%' and idUser=".$_Session['idUser']." order by ".$orden;
__________________
Quim
--------------------------------------------------
Ayudar a ayudar es una buena práctica!!! Y da buenos resultados.
  #3 (permalink)  
Antiguo 03/11/2013, 14:05
 
Fecha de Ingreso: octubre-2011
Mensajes: 17
Antigüedad: 13 años, 1 mes
Puntos: 0
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

Gracias la respuesta quimfv. Entiendo lo que quieres decir, mi duda ahora es como guardo esa información? Tendría que crear un campo para eso en la tabla productos?
  #4 (permalink)  
Antiguo 03/11/2013, 14:09
Avatar de adryan310  
Fecha de Ingreso: septiembre-2012
Mensajes: 450
Antigüedad: 12 años, 2 meses
Puntos: 3
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

Cita:
Iniciado por Jozinei Ver Mensaje
Gracias la respuesta quimfv. Entiendo lo que quieres decir, mi duda ahora es como guardo esa información? Tendría que crear un campo para eso en la tabla productos?
Asi es amigo deberias hacerlo, al menos que tengas una tabla usuarios entonces lo que haces es almacenar el id osea campo primario de la tabla usuarios en la tabla productos y asi ese id que se registra estara conectado como llave foranea con la tabla usuarios. Es mas factible hacerlo asi ya que si tienes toda la informacion del usuario la puedes presentar con mejor especificacion, ejemplo: el usuario que registro el producto X se llama: Jose Andres Matarrita Sossa con la cedula de identidad numero 1-111-111. Espero me halla explicado bien
  #5 (permalink)  
Antiguo 03/11/2013, 14:13
 
Fecha de Ingreso: octubre-2011
Mensajes: 17
Antigüedad: 13 años, 1 mes
Puntos: 0
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

Gracias Adryan. Entiendo perfectamente lo que quieres decir, y en mi caso, si, tengo una tabla usuarios. Voy a probar hacer la relación y ver como puedo solucionar mi problema. Más una vez gracias por las respuestas =)
  #6 (permalink)  
Antiguo 11/12/2013, 11:48
 
Fecha de Ingreso: octubre-2011
Mensajes: 17
Antigüedad: 13 años, 1 mes
Puntos: 0
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

Cita:
Iniciado por quimfv Ver Mensaje
La unica forma de hacerlo es que al guardar un producto guardes quien lo ha registrado. Es decir debes guardar el id del usuario al mismo timpo que guardas el producto en la tabla productos ... luego la consulta la debes limitar por el usuario actual...


$sql = "select * from tabla where tbl_campo like '".$filtrar_por."%' and idUser=".$_Session['idUser']." order by ".$orden;
Hola de nuevo amigos, estuve intentando resolver de esa forma pero resulta que me sale el siguiente error:

1054: Unknown column 'admin' in 'where clause'

Tengo las tablas:
a) usuarios
b) alquileres

Al momento de hacer un registro de un alquiler, también estoy alquilando en la tabla alquileres el nombre del usuario que realizó el registro (en este caso 'admin').

Mi código select es así:

$sql = "select * from alquileres where ALQ_TIERRA like '".$filtrar_por."%' and ALQ_USUARIO = ".$_SESSION['nombre_usu']." order by ".$orden;

Donde el campo ALQ_USUARIO guarda el nombre del usuario que realizó el registro. Al hacer el registro de un alquiler no tengo ningún problema, el error es en efectuar el select.

Así sale mi consulta:

(mysql): select * from alquileres where ALQ_TIERRA like '%' and ALQ_USUARIO = admin order by ALQ_TIERRA
  #7 (permalink)  
Antiguo 11/12/2013, 12:57
 
Fecha de Ingreso: octubre-2011
Mensajes: 17
Antigüedad: 13 años, 1 mes
Puntos: 0
Respuesta: Hacer que cada usuario vea solamente los datos registrados por el mismo

Problema solucionado, todo era cuestión de comillas. El código final:

$sql = "select * from alquileres where ALQ_TIERRA like '".$filtrar_por."%' and ALQ_USUARIO = '".$_SESSION['nombre_usu']."' order by ".$orden;

Etiquetas: cada, formulario, registro, select, solamente, sql, tabla, usuario, usuarios, vea
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 09:33.