Foros del Web » Programando para Internet » PHP »

Cómo sabes cuantos campos tiene una tabla de la base de datos???

Estas en el tema de Cómo sabes cuantos campos tiene una tabla de la base de datos??? en el foro de PHP en Foros del Web. Hola me gustaría saber alguna consulta sql para saber la cantidad de campos que tiene una tabla. Gracias....
  #1 (permalink)  
Antiguo 18/05/2008, 15:32
 
Fecha de Ingreso: febrero-2008
Mensajes: 76
Antigüedad: 16 años, 2 meses
Puntos: 0
Cómo sabes cuantos campos tiene una tabla de la base de datos???

Hola me gustaría saber alguna consulta sql para saber la cantidad de campos que tiene una tabla.

Gracias.
  #2 (permalink)  
Antiguo 18/05/2008, 17:03
 
Fecha de Ingreso: junio-2007
Ubicación: por ahi
Mensajes: 262
Antigüedad: 16 años, 10 meses
Puntos: 4
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Desafortunadamente la consulta no es unica y depende del motro de bases de datos que se este usando. Que motor de base de datos usas?
__________________
Hernando Saenz Sanchez
  #3 (permalink)  
Antiguo 19/05/2008, 03:46
 
Fecha de Ingreso: febrero-2008
Mensajes: 76
Antigüedad: 16 años, 2 meses
Puntos: 0
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Uso MySQL, espero que puedas ayudarme gracias.
  #4 (permalink)  
Antiguo 19/05/2008, 06:38
 
Fecha de Ingreso: mayo-2005
Mensajes: 188
Antigüedad: 19 años
Puntos: 6
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Aunque supongo que habrá una manera más elegante puedes hacer un
Código:
SELECT * FROM nombre_tabla LIMIT 1
y luego contar los campos recibidos en la consulta.
  #5 (permalink)  
Antiguo 19/05/2008, 08:11
 
Fecha de Ingreso: abril-2008
Ubicación: Argentina
Mensajes: 75
Antigüedad: 16 años, 1 mes
Puntos: 0
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Debería hacerlo de este modo:

Código:
select count(nombre_columna) as 'Alias' from nombre_tabla;
  #6 (permalink)  
Antiguo 19/05/2008, 08:29
isra00
Invitado
 
Mensajes: n/a
Puntos:
De acuerdo Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Hay varias maneras. La primera es pedirlos directamente a MySQL con:

Código:
SHOW FIELDS FROM tabla
Pruébalo en la consola MySQL para ver cómo funciona, porque además de devolver los nombres de los campos también devuelve el tipo, clave, atributos, etc.

La otra manera, que es útil si quieres ejecutar una consulta, es por PHP:

Código PHP:
$c=mysql_query("SELECT * FROM tabla WHERE...");
$r=mysql_fetch_assoc($c);
foreach (
$r as $campo=>$valor) echo $campo;
mysql_data_seek($r);
while (
$r=mysql_fetch_assoc($c) {
 
//Lo que quieras hacer con la consulta

La primera vez que hago mysql_fetch_assoc recorro el array $r con foreach y la variable $campo me devuelve los nombres de los campos. Después ejecuto mysql_data_seek para devolver el puntero interno a la primera fila de resultados, ya que mysql_fetch_array avanza una posición cada vez que se invoca. Si no ejecutase mysql_data_seek, el bucle while, que recorre los resultados, empezaría por la segunda fila de resultados.

Como te digo, el primer método es útil si simplemente quieres saber los campos de la tabla y no vas a ejecutar ninguna otra consulta. El segundo método es más eficiente cuando estás trabajando con consultas "del mundo real", ya que no tienes que hacer una consulta más de "SHOW FIELDS", sino que aprovechas los campos del resultado de la consulta.

Espero que sirva de ayuda. Un abrazo,
Isra
  #7 (permalink)  
Antiguo 19/05/2008, 08:58
Avatar de ACX_POISON  
Fecha de Ingreso: abril-2008
Ubicación: Talca-Chile
Mensajes: 750
Antigüedad: 16 años, 1 mes
Puntos: 7
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Tambien prueba con esto

$cons="SELECT * FROM tabla"
$sql=mysql_query($cons);
$numero_campos=mysql_num_fields($sql);

devolverá el numero de campos de la ultima consulta y como estan seleccionados todos dira el total
  #8 (permalink)  
Antiguo 19/05/2008, 09:08
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 18 años
Puntos: 2135
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Es mucho más barato a nivel recursos, y es más rápido, usar la opción que pone jonathan_miguel, aparte de que es la más estándar y funciona en varios motores de BDD.

Saludos.
  #9 (permalink)  
Antiguo 19/05/2008, 09:27
isra00
Invitado
 
Mensajes: n/a
Puntos:
Respuesta: Cómo sabes cuantos campos tiene una tabla de la base de datos???

Cita:
Iniciado por GatorV Ver Mensaje
Es mucho más barato a nivel recursos, y es más rápido, usar la opción que pone jonathan_miguel, aparte de que es la más estándar y funciona en varios motores de BDD.
No necesariamente. Usando mysql_num_fields o recorriendo el array asociativo ahorramos una consulta SQL.
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 11:18.