Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > PHP
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-05-2006
Shidalis Shidalis is offline
Miembro
 
Registrado: jul 2005
Posts: 106
Poder: 19
Shidalis Va por buen camino
Question Como concateno los nombres de los campos de una tabla en mysql

Saludos a todos.
Esta es mi pregunta como hago para concatenar los nombres de los campos de una tabla en una variable.
Tengo entendido que en ASP se usa la siguiente propiedad para tomar los nombre de los campos:
Código:
    rst.Fields(i).Name
Como hago para hacer el equivalente a este codigo
Responder Con Cita
  #2  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

No me queda muy clara tu pregunta Shidalis. ¿Estas trayendo registros de la base de datos y quieres acceder a estos por los nombres de sus campos? ¿Se trata de concatenar los nombres de los campos a las correspondientes tablas al realizar una consulta SQL? O a lo mejor es otra cosa y... bueno, por eso digo que no me queda muy clara la cuestión.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #3  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Código PHP:
mysql_connect(blahblahblah);
$resultados mysql_query(blahblah);
while (
$field mysql_fetch_field($resultados)
{
  echo 
$field->name;

// Saludos
Responder Con Cita
  #4  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Disculpa Román, con "mysql_fetch_field", ¿qué trae uno exactamente? ¿Los nombres de los campos? ¿Alguna otra información además? ¿Qué consulta SQL produce los resultados que necesita esa función? ¿Es algo así como una especie de "wrapper" para las consultas DESCRIBE de MySQL? Muchas preguntas...
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #5  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
Muchas preguntas...
Una respuesta

Qué consulta usar, podría ser:

Código SQL [-]
select * from tabla where 1=0

// Saludos
Responder Con Cita
  #6  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Ejem... sí, bueno, el manual de PHP... no sé porqué había pensado que podrías responderme tú mismo.

Ya estoy echando un vistazo a ver qué sacamos en claro.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #7  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
no sé porqué había pensado que podrías responderme tú mismo.
¡Ah no señor! Mismo trato que a los demás foristas

Además, hasta cierto punto, sí lo digo yo mismo aquí

// Saludos
Responder Con Cita
  #8  
Antiguo 25-05-2006
Shidalis Shidalis is offline
Miembro
 
Registrado: jul 2005
Posts: 106
Poder: 19
Shidalis Va por buen camino
Unhappy

disculpa roman hice lo siguiente

Código PHP:
$con mysql_connect($bd_host$bd_usuario$bd_password);
$resultados mysql_query("Select * from tabla"$con); 
while (
$field=mysql_fetch_field($resultados)

  echo 
$field->name

y me arrojo el siguiente error

Código PHP:
Parse errorsyntax errorunexpected '{' in C:\wamp\www\PaginaWeb\ejecutar.php on line 5 
Responder Con Cita
  #9  
Antiguo 25-05-2006
Avatar de D-MO
D-MO D-MO is offline
Miembro
 
Registrado: ago 2005
Ubicación: root@debian:/#
Posts: 1.042
Poder: 20
D-MO Va por buen camino
Código PHP:
$con mysql_connect($bd_host$bd_usuario$bd_password);
$resultados mysql_query("Select * from tabla"$con); 
while (
$field=mysql_fetch_field($resultados))

  echo 
$field->name

Así está mejor.

Saludos.
Responder Con Cita
  #10  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Si lo que nos interesa es traer la información de los campos, parece que funciona igual si se realiza una consulta limitada:

Código SQL [-]
SELECT * FROM tabla LIMIT 1

También funciona solicitando un solo campo, o discriminando con la ayuda de "WHERE", pero, no sé yo si no queda más curioso y además es más escalable (no haría falta conocer el nombre del campo, no hace falta el "WHERE" tampoco, únicamente el nombre de la tabla) haciéndolo como digo arriba.
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #11  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Sip, me faltó un paréntesis:

while ($field=mysql_fetch_field($resultados)

Al margen de esta errata, si lo único que necesitas es la información de los campos de la tabla, sería mejor que le pusieras una condición imposible a la consulta:

Código SQL [-]
select * from tabla where 1=0

pues así evitas traerte innecesariamente todos los registros.

También puede interesarte la consulta

Código SQL [-]
describe table

que te devolverá información específica de la tabla.

// Saludos
Responder Con Cita
  #12  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
como digo arriba.
Uy, disculpa, no me había fijado que desde un principo habías mencionado a describe. Ciertamente, si sólo interesa la meta-data, bastará con eso.

// Saludos
Responder Con Cita
  #13  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Ahora lo he cogido... o sea, que ni "WHERE", ni "LIMIT", ni nada. Basta con realizar una consulta "DESCRIBE" y obtenemos los mismos resultados sin necesidad de traernos registro alguno.

Edito: Si utilizamos la función "mysql_fetch_results" luego de realizar una consulta "DESRIBE" obtenemos también información:

Código:
stdClass Object
(
  [Field] => help_keyword_id
  [Type] => int(10) unsigned
  [Null] =>
  [Key] => PRI
  [Default] => 0
  [Extra] =>
)
Pero, si utlizamos la función "mysql_fetch_field" las posibilidaes aumentan:

Código:
stdClass Object
(
  [name] => name
  [table] => help_keyword
  [def] =>
  [max_length] => 3
  [not_null] => 1
  [primary_key] => 0
  [multiple_key] => 0
  [unique_key] => 1
  [numeric] => 0
  [blob] => 0
  [type] => string
  [unsigned] => 0
  [zerofill] => 0
)
Dicho sea como de paso...
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 25-05-2006 a las 22:13:55.
Responder Con Cita
  #14  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
sin necesidad de traernos registro alguno
Aunque llevas razón, nota que con la consulta que yo propongo no te traes ni un sólo registro. No al menos mientras las matemáticas insistan en que 1 es distinto de 0.

// Saludos
Responder Con Cita
  #15  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
Si utilizamos la función "mysql_fetch_results"
No conozco esta función.

// Saludos
Responder Con Cita
  #16  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
David, examina con detalle la información que te da una y otra forma. Realmente es prácticamente los mismo. La única parte de más es la de max_length, pero no podía ser de otra forma, ya que max_length se refiere a la máxima longitud de entre los registros devueltos, es decir, no forma parte de la estructura de la tabla.

// Saludos
Responder Con Cita
  #17  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Cita:
Empezado por Román
No conozco esta función.
A ver si va a ser que no existe... Me refería a: "mysql_fetch_object" y se me fue la mano.

Cita:
Empezado por Román
Aunque llevas razón, nota que con la consulta que yo propongo no te traes ni un sólo registro. No al menos mientras las matemáticas insistan en que 1 es distinto de 0.
¿Y quién te dice a ti que... No. Vas a llevar razón, no había caído en ese "detalle"...
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #18  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Cita:
Empezado por Román
David, examina con detalle la información que te da una y otra forma. Realmente es prácticamente los mismo. La única parte de más es la de max_length, pero no podía ser de otra forma, ya que max_length se refiere a la máxima longitud de entre los registros devueltos, es decir, no forma parte de la estructura de la tabla.
¿Seguro? En el manual dice lo siguiente, lo mismo es que yo lo entiendo mal:

Cita:
max_length - maximum length of the column
Y, por otro lado, me estoy perdiendo algo o veo más resultados de una forma que de otra... ¿dónde quedan los valores: "numeric", "is_blob", "unique_key", etc.?
__________________
David Esperalta
www.decsoftutils.com
Responder Con Cita
  #19  
Antiguo 25-05-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por dec
¿Seguro?
99%

Fíjate en el tercer comentario del manual. Claro que es el comentario de un usuario pero bastaría hacer unas cuantas pruebas. Por otra parte, la API de PHP para MySql está basada casi totalmente en la API de C, en donde sí especifica lo que te comento.


Cita:
Empezado por dec
Y, por otro lado, me estoy perdiendo algo o veo más resultados de una forma que de otra... ¿dónde quedan los valores: "numeric", "is_blob", "unique_key", etc.?
Por eso te digo que hay que examinarlo con detalle. El DESCRIBE te devuelve en [Key] el tipo de clave, lo cual abarca [primary_key], [multiple_key] y [unique_key]. En [Type] puede devolverte algo como

int(11) unsigned zerofill

es decir, abarca [unsigned], [zero fill] y [type] y posiblemente también [blob]. Otra que no viene en DESCRIBE es [table] pero esa no la necesitas ¿verdad?

// Saludos
Responder Con Cita
  #20  
Antiguo 25-05-2006
Avatar de dec
dec dec is offline
Moderador
 
Registrado: dic 2004
Ubicación: Alcobendas, Madrid, España
Posts: 13.107
Poder: 34
dec Tiene un aura espectaculardec Tiene un aura espectacular
Hola,

Ya comprendo. O sea, se devuelven los mismo datos, solo que digamos que PHP los organiza en las propiedades de un objeto al utilizar "mysql_fetch_field". Yo estoy haciendo unas pruebas y mira cómo me va quedando un posible método para la clase "bdatos.class" que me traigo entre manos:

Código PHP:
  /**
   * Devuelve un Array  de dos dimensiones en el que se
   * puede encontrar información sobre  cada uno de los
   * campos que componen una determina tabla en la base
   * de datos.
   * 
   * @param string $tabla
   * @return array
   * @access public
   */
  
function Campos($tabla
  {
    if(!isset(
$tabla) || $tabla == '')
      return 
false;
    
    
$resultadoMetodo   = array();    
            
    
$resultadoConsulta mysql_query
      
("SELECT * FROM $tabla WHERE 0=1"$this->enlaceConexionBd);
        
    
$i 0;            
    while (
$infoCampo mysql_fetch_field($resultadoConsulta)) 
    {      
      
$resultadoMetodo[$i]['nombre']          = $infoCampo->name;      
      
$resultadoMetodo[$i]['porDefecto']      = $infoCampo->def;
      
$resultadoMetodo[$i]['esBlob']          = $infoCampo->blob;
      
$resultadoMetodo[$i]['tipo']            = $infoCampo->type;
      
$resultadoMetodo[$i]['tabla']           = $infoCampo->table;
      
$resultadoMetodo[$i]['esNumerico']      = $infoCampo->numeric;
      
$resultadoMetodo[$i]['admiteNulos']     = $infoCampo->not_null;
      
$resultadoMetodo[$i]['sinSigno']        = $infoCampo->unsigned;
      
$resultadoMetodo[$i]['rellenoCeros']    = $infoCampo->zerofill;
      
$resultadoMetodo[$i]['maxLongitud']     = $infoCampo->max_length;
      
$resultadoMetodo[$i]['esClaveUnica']    = $infoCampo->unique_key;
      
$resultadoMetodo[$i]['esClavePrimaria'] = $infoCampo->primary_key;
      
$resultadoMetodo[$i]['claveMultiple']   = $infoCampo->multiple_key;
      
$i++;   
    }
        
    
mysql_free_result($resultadoConsulta);      
    return 
$resultadoMetodo;     
  } 
¿Qué tal parece? Funcionar parece que funciona, aunque probablemente es mejorable el asunto.
__________________
David Esperalta
www.decsoftutils.com

Última edición por dec fecha: 25-05-2006 a las 23:08:40.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Como agregar a una lista los nombres de los campos de una consulta. Luis Conexión con bases de datos 2 11-11-2004 21:55:56
Como obtener los Campos de una Tabla ? mtpedro Conexión con bases de datos 1 27-10-2004 02:11:00
Como concateno cadenas en Firebird?¿? burasu Firebird e Interbase 6 21-07-2004 13:38:29
Como creo campos en una tabla Paradox?? JoseQ Conexión con bases de datos 1 13-07-2004 19:07:09
¿Modificar nombres de campos por SQL? m@r SQL 3 22-10-2003 01:30:49


La franja horaria es GMT +2. Ahora son las 23:32:56.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi