Foros del Web » Programando para Internet » PHP »

Asignar valor de una DB a una variable

Estas en el tema de Asignar valor de una DB a una variable en el foro de PHP en Foros del Web. Hola. Tratare de ser claro (no usare acentos). Tengo un BD con una tabla 'usuarios' y campos 'user' 'pass' 'nivel_acceso'. Segun el user y pass ...
  #1 (permalink)  
Antiguo 29/01/2008, 12:42
 
Fecha de Ingreso: marzo-2007
Mensajes: 21
Antigüedad: 17 años, 1 mes
Puntos: 0
Pregunta Asignar valor de una DB a una variable

Hola. Tratare de ser claro (no usare acentos).
Tengo un BD con una tabla 'usuarios' y campos 'user' 'pass' 'nivel_acceso'.
Segun el user y pass le doy un nivel_acceso distinto.
Ejemplo: user=bishop pass=bishop nivel=1 , user=pepe pass=pepe nivel=2.
El nivel_acceso 1 es mayor que el 2.
Ahora no se como asignar el valor de nivel_acceso a una variable tipo $r.

Lo que tengo y no me funciona es esto:

$q = '
SELECT nivel_acceso FROM usuario
WHERE nombre_usuario ="' . $nombre_usuario . '"
';
$r = mysql_query($q);


if ( $r == 1 ){
...
} else{
...
}


Sé que esta mal, pero como asigno a $r (u otra variable) el valor de nivel_acceso ?
Espero se entienda.Gracias.
  #2 (permalink)  
Antiguo 29/01/2008, 12:47
 
Fecha de Ingreso: noviembre-2002
Mensajes: 1.341
Antigüedad: 21 años, 5 meses
Puntos: 17
Re: Asignar valor de una DB a una variable

¿Por qué no lees un manual básico de MySQL + PHP? Te evitarás muchas preguntas de éste tipo...

Lo básico es:

- Conectar al servidor de BDD (mysql_connect)
- Seleccionar la BDD (mysql_select_db)
- Realizar una query (mysql_query)
- Recorrer la query sacando los resultados (mysql_fetch_array)

En tu caso te faltaría hacer un mysql_fetch_array (asignándoselo a una variable) y luego recoger el valor que estará en $variable['campo_de_la_bdd']

Pero insisto, lee un manual.
  #3 (permalink)  
Antiguo 29/01/2008, 13:32
 
Fecha de Ingreso: marzo-2007
Mensajes: 21
Antigüedad: 17 años, 1 mes
Puntos: 0
Re: Asignar valor de una DB a una variable

1º- gracias por responder.

2º- Estoy leyendo el Manual de PHP y el libro "PHP_MySQL_Programming_for_the_Absolute_Beginn er".

3º- Sucede que aún no he llegado a 'entender' algunas cosas.
4º- No todos aprendemos rápido, algunos tardamos más.

5º- Habia hecho la consulta, pero me faltaba como decis vos, 'cargarlo' en el array, para luego asignarlo a la variable.

6º- Nuevamente muchas gracias.

  #4 (permalink)  
Antiguo 29/01/2008, 13:40
 
Fecha de Ingreso: noviembre-2002
Mensajes: 1.341
Antigüedad: 21 años, 5 meses
Puntos: 17
Re: Asignar valor de una DB a una variable

No lo decía con prepotencia ni nada parecido. Pero es una duda básica, no sé qué manuales seguirás, pero suelen poner ejemplos de éste tipo al empezar con estos conceptos. Y luego el manual de php.net también ayuda mucho.
  #5 (permalink)  
Antiguo 29/01/2008, 14:05
 
Fecha de Ingreso: mayo-2007
Ubicación: Chile
Mensajes: 42
Antigüedad: 17 años
Puntos: 1
Re: Asignar valor de una DB a una variable

Compadre, yo usaria el siguiente bucle en vez de if:
Swich que va buscando condiciones y cuando la encuentra da un break y sigue con la ejecucion del script.

Código PHP:
<?php


switch ($r) {
    case 
"1":
     
// código que se ejecuta si $r vale "1"
    
break;

    case 
"2":
     
// código que se ejecuta si $r vale "2"
    
break;
    case 
"3":
     
// código que se ejecuta si $r vale "3"
    
break;
    default:
    
// código a ejecutar por defecto si no se cumple ninguna condición
}

?>
Ojala sea lo que buscas.


Saludos
  #6 (permalink)  
Antiguo 29/01/2008, 16:10
 
Fecha de Ingreso: marzo-2007
Mensajes: 21
Antigüedad: 17 años, 1 mes
Puntos: 0
Re: Asignar valor de una DB a una variable

Keysher:
No lo tome con prepotencia ni nada parecido, al contrario, agradezco tu ayuda porque suelo 'andar' por varios foros y he ayuda (muy poco) y es una gran alegria saber que ayudas a alguien. nuevamente gracias, de verdad.

Keison:
Probaré lo que dices, aunque hice algo similar, solo que luego del case, no use comillas dobles (").

De todas formas mi problema es que no logro asignar el valor que tiene la BD en el campo "nivel_acceso".

Última edición por bishop365; 29/01/2008 a las 16:16
  #7 (permalink)  
Antiguo 30/01/2008, 08:26
 
Fecha de Ingreso: mayo-2007
Ubicación: Chile
Mensajes: 42
Antigüedad: 17 años
Puntos: 1
Re: Asignar valor de una DB a una variable

bishop como vas con tu problema?
estas seguro de que si lees el nivel de acceso, puedes probar eso con un echo, pues puede que no lo leas y que el problema este ahi.

Estamos comunicandonos.
  #8 (permalink)  
Antiguo 30/01/2008, 13:50
 
Fecha de Ingreso: marzo-2007
Mensajes: 21
Antigüedad: 17 años, 1 mes
Puntos: 0
Busqueda Re: Asignar valor de una DB a una variable

Efectivamente, no logré solucionarlo. No me doy cuenta como asignar el valor que esta en la BD a una variable. Pongo el código completo. Aclaro que el campo 'nivel_acceso' es int.
Son dos formas distintas y no logro que funcionen, es como que el if == 1 no se hace, salta al else directamente.

--------------------------

function lista_usuarios(){

$q = 'SELECT nivel_acceso FROM usuario WHERE nombre_usuario ="' . $nombre_usuario . '"';
$r = mysql_query($q);
$p = mysql_fetch_array($r);
$valor_nivel_acceso = $p['nivel_acceso'];


switch ($valor_nivel_acceso) {
case "1":
echo '<table bgcolor="#98B8D8" align="center" border="1">';
echo '<tr>';
echo '<th>Nombre de Usuario</th>';
echo '<th>Contraseña</th>';
echo '<th>Apellido y nombre</th>';
echo '<th>Nivel Acceso</th>';
echo '<th colspan="2">Acciones</td>';
echo '</tr>';
......

--------------------------
OTRO CODIGO SIMILAR


function lista_usuarios(){

$q = 'SELECT nivel_acceso FROM usuario WHERE nombre_usuario ="' . $nombre_usuario . '"';
$r = mysql_query($q);
$p = mysql_fetch_array($r);
$valor_nivel_acceso = $p['nivel_acceso'];


if ( $valor_nivel_acceso == 1 ) {
echo '<table bgcolor="#98B8D8" align="center" border="1">';
echo '<tr>';
echo '<th>Nombre de Usuario</th>';
echo '<th>Contraseña</th>';
echo '<th>Apellido y nombre</th>';
echo '<th>Nivel Acceso</th>';
echo '<th colspan="2">Acciones</td>';
echo '</tr>';
........
} else {
echo ......


Cuando keysher menciona lo de asignar variables, se refiere a variables de todo tipo, el temna esta en que no logro asignar el valor que leo de la BD.
Respecto a mysql_fetch_array() , se supone que puede ser un array de una dimension, o estoy equivocado?
Nuevamente agradezco la ayuda.
  #9 (permalink)  
Antiguo 07/02/2008, 09:17
 
Fecha de Ingreso: marzo-2007
Mensajes: 21
Antigüedad: 17 años, 1 mes
Puntos: 0
Re: Asignar valor de una DB a una variable

Solucionado. Lo que hice fue, a la funcion lista_user() la modifique por lista_user($nivel). Luego al hacer el logim, tomo el valor de nivel y se lo paso a la funcion. gracias a TODOS los que leyeron el post y respondieron. Lo mejor de los foros es que uno aprende del otro.
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 20:18.