Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   PHP (https://www.clubdelphi.com/foros/forumdisplay.php?f=15)
-   -   Como concateno los nombres de los campos de una tabla en mysql (https://www.clubdelphi.com/foros/showthread.php?t=32081)

Shidalis 25-05-2006 20:44:45

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

dec 25-05-2006 20:51:02

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. ;)

roman 25-05-2006 20:57:57

Código PHP:

mysql_connect(blahblahblah);
$resultados mysql_query(blahblah);
while (
$field mysql_fetch_field($resultados)
{
  echo 
$field->name;


// Saludos

dec 25-05-2006 21:07:56

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... :D :eek:

roman 25-05-2006 21:11:36

Cita:

Empezado por dec
Muchas preguntas...

Una respuesta

Qué consulta usar, podría ser:

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

// Saludos

dec 25-05-2006 21:14:34

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. :D

roman 25-05-2006 21:25:19

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 :p :D

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

// Saludos

Shidalis 25-05-2006 21:33:43

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 


D-MO 25-05-2006 21:51:19

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.

dec 25-05-2006 21:53:28

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.

roman 25-05-2006 21:54:11

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

roman 25-05-2006 21:56:29

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

dec 25-05-2006 22:10:14

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. :eek: :D

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... :D

roman 25-05-2006 22:14:30

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

roman 25-05-2006 22:16:21

Cita:

Empezado por dec
Si utilizamos la función "mysql_fetch_results"

No conozco esta función.

// Saludos

roman 25-05-2006 22:26:49

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

dec 25-05-2006 22:27:14

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"... :D

dec 25-05-2006 22:34:52

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.?

roman 25-05-2006 22:51:05

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

dec 25-05-2006 23:02:32

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. :D


La franja horaria es GMT +2. Ahora son las 19:21:34.

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