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

roman 25-05-2006 23:12:02

¿Para qué quieres $i?

EDITO:

Código PHP:

while ($infoCampo mysql_fetch_field($resultadoConsulta)) 
{      
    
$resultado['nombre']          = $infoCampo->name;      
    
$resultado['porDefecto']      = $infoCampo->def;
    
$resultado['esBlob']          = $infoCampo->blob;
    
$resultado['tipo']            = $infoCampo->type;
    
$resultado['tabla']           = $infoCampo->table;
    
$resultado['esNumerico']      = $infoCampo->numeric;
    
$resultado['admiteNulos']     = $infoCampo->not_null;
    
$resultado['sinSigno']        = $infoCampo->unsigned;
    
$resultado['rellenoCeros']    = $infoCampo->zerofill;
    
$resultado['maxLongitud']     = $infoCampo->max_length;
    
$resultado['esClaveUnica']    = $infoCampo->unique_key;
    
$resultado['esClavePrimaria'] = $infoCampo->primary_key;
    
$resultado['claveMultiple']   = $infoCampo->multiple_key;

    
$resultadoMetodo[] = $resultado;


// Saludos

dec 26-05-2006 07:40:12

Hola,

Este Román... que para qué quiero "$i" dice... anda que... De momento el método va quedando así:

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);
        
    while (
$infoCampo mysql_fetch_field($resultadoConsulta)) 
    {      
      
$campo = array();
        
      
$campo['nombre']          = $infoCampo->name;
      
$campo['porDefecto']      = $infoCampo->def;
      
$campo['esBlob']          = $infoCampo->blob;
      
$campo['tipo']            = $infoCampo->type;
      
$campo['tabla']           = $infoCampo->table;
      
$campo['esNumerico']      = $infoCampo->numeric;
      
$campo['admiteNulos']     = $infoCampo->not_null;
      
$campo['sinSigno']        = $infoCampo->unsigned;
      
$campo['rellenoCeros']    = $infoCampo->zerofill;
      
$campo['maxLongitud']     = $infoCampo->max_length;
      
$campo['esClaveUnica']    = $infoCampo->unique_key;
      
$campo['esClavePrimaria'] = $infoCampo->primary_key;
      
$campo['claveMultiple']   = $infoCampo->multiple_key;
      
      
$resultadoMetodo[] = $campo;
    }
        
    
mysql_free_result($resultadoConsulta);      
    return 
$resultadoMetodo;     
  } 

... pero anda que preguntar para qué quiero "$i"... si es que... :eek::eek::eek: :D:D:D

De todos modos hay que darle alguna que otra vuelta más a esto. No sé si con el método "Campos" es bastante (la verdad es que no suelo necesitar saber de qué tipo es un campo, pero también es que no he hecho muchas cosas que digamos) o merecerá la pena entretenerse un poco más a ver de qué forma puede presentarse esa información que sea mejor para quien la requiera. ;)

PD. Gracias por lo de la $i Román. :D

dec 26-05-2006 10:30:56

Hola,

Mira cómo va quedando la cosa Román. He preparado una clase auxiliar para la clase "bdatos.class" que ya casi puedo decir que estamos haciendo... :D

Código PHP:

/**
 * 
 * @name InfoCampo
 * @access private
 * @package phpclasses
 * @version 0.1 26/5/2006
 * @author David Esperalta
 * @link mailto:[email protected]
 * 
 * @copyright 2006 David Esperalta
 * 
 */
class InfoCampo 
{
  
/**
   * Nombre del campo
   *
   * @var string
   * @access public
   */
  
var $nombre '';

  
/**
   * Nombre de la tabla
   *
   * @var string
   * @access public
   */  
  
var $tabla '';

  
/**
   * Valor por defecto
   *
   * @var string
   * @access public
   */    
  
var $porDefecto '';
  
  
/**
   * Máxima longitud
   *
   * @var integer
   * @access public
   */    
  
var $maxLogitud 0;

  
/**
   * ¿Admite valores nulos?
   *
   * @var integer
   * @access public
   */    
  
var $admiteNulos 0;

  
/**
   * ¿Es clave primaria?
   *
   * @var integer
   * @access public
   */    
  
var $esClavePrimaria 0;
  
  
/**
   * ¿Es clave única?
   *
   * @var integer
   * @access public
   */      
  
var $esClaveUnica 0;
  
  
/**
   * ¿Es clave múltiple?
   *
   * @var integer
   * @access public
   */      
  
var $esClaveMultiple 0;
  
  
/**
   * ¿Es de tipo numérico?
   *
   * @var integer
   * @access public
   */      
  
var $esNumerico 0;
  
  
/**
   * ¿Es de tipo "Blob"?
   *
   * @var integer
   * @access public
   */      
  
var $esBlob 0;

  
/**
   * Nombre del tipo
   *
   * @var string
   * @access public
   */      
  
var $tipo '';
  
  
/**
   * ¿Tiene signo?
   *
   * @var integer
   * @access public
   */      
  
var $sinSigno 0;
  
  
/**
   * ¿Se rellena con ceros?
   *
   * @var integer
   * @access public
   */
  
var $rellenoCeros 0;   
  
  
/**
   * Constructor de la clase
   *
   * El parámetro ha de ser un objeto del tipo
   * que devuelve la función "mysql_fech_field".
   * 
   * @param Object $datosCampo
   * @return InfoCampo
   * @access public
   */
  
function InfoCampo($datosCampo)
  {
    if(!isset(
$datosCampo))
      return 
null;
    
$this->CargarInfo($datosCampo);  
  }
  
  
/**
   * Traladamos las propiedades del objeto que
   * se pasa como parámetro a este propio objeto.
   * 
   * En realidad, como puede verse, lo único que
   * hacemos es "traducir" las propiedades del in-
   * glés al español.
   *
   * @param Object $datosCampo
   * @access private
   */
  
function CargarInfo($datosCampo)
  {
    
$this->nombre          $datosCampo->name;
    
$this->tabla           $datosCampo->table;
    
$this->porDefecto      $datosCampo->def;
    
$this->maxLogitud      $datosCampo->max_length;
    
$this->admiteNulos     $datosCampo->not_null;
    
$this->esClavePrimaria $datosCampo->primary_key;
    
$this->esClaveUnica    $datosCampo->unique_key;
    
$this->esClaveMultiple $datosCampo->multiple_key;
    
$this->esNumerico      $datosCampo->numeric;
    
$this->esBlob          $datosCampo->blob;
    
$this->tipo            $datosCampo->type;
    
$this->sinSigno        $datosCampo->unsigned;
    
$this->rellenoCeros    $datosCampo->zerofill;
  }

// class InfoCampo 

Como puede verse la clase no sirve para mucho... todavía dudo de su utilidad, pero, en todo caso, está pensada (es un decir) para utilizarse en el nuevo método "Campos" de la clase "bdatos.class", tal que así:

Código PHP:

  /**
   * Devuelve información acerca de los campos de una
   * determinada tabla de la base de datos. El resul-
   * tado de este método puede consistir en un Array
   * de Objetos, un Array de Arrays asociativos o un
   * Array de Arrays numéricos.
   * 
   * @param string $tabla Nombre de la tabla
   * @return mixed array
   * @access public
   */
  
function Campos($tabla$tipoSalida TS_OBJETO
  {
    
// Comprobamos que se especifica una tabla
    
if(!isset($tabla) || $tabla == '')
      return 
false;
    
    
// Preparamos el resultado
    
$resultadoMetodo   = array();    
           
    
/* Nótese lo "mágico" de la consulta.
       (Gracias Román ;)
    */
    
$sql "SELECT * FROM $tabla WHERE 0 = 1";
    
    
/* ¿Porqué no utilizamos el método Consulta conque cuenta
       esta misma clase para obtener los resultados? La razón
       está en que el método Consulta no devuelve un "recurso"
       como lo hace "mysql_query", así que no podríamos luego
       utilizar el resultado más abajo, como se verá.
    */
    
$resultadoConsulta = @mysql_query($sql$this->enlaceConexionBd);
        
    
// ¿Algún error en la sala?
        
if(@mysql_error($this->enlaceConexionBd))
        {
            
$this->Error(@mysql_error($this->enlaceConexionBd));
            return 
false;
        }              

        
/* Es aquí donde necesitamos un resultado como el que nos
           devuelve la función "mysql_query", para utilizarlo en
           la función "mysql_fetch_field".
        */
    
while ($datosCampo = @mysql_fetch_field($resultadoConsulta)) 
    {            
      
/* Esto puede ser un poco estúpido. Lo único que
         nos ofrece la clase "InfoCampo" es un objeto
         cuyas propiedades son las mismas que el objeto
         que ahora contiene "$datosCampo". La diferencia
         está en que en el objeto "InfoCampo" sus propie-
         dades están en español. ¿Será esto útil?           
      */
      
$infoCampo = new InfoCampo($datosCampo);
      
      
/* A continuación toca mirar por el tipo de salida
         que se precisa, por defecto un Array de objetos,
         como en el resto de métodos de esta clase que
         devuelven datos.
      */
      
switch ($tipoSalida
      {
          case 
TS_ARRAY_ASOCIATIVO:
              
$resultadoMetodo[] = get_object_vars($infoCampo);
              break;
        case 
TS_ARRAY_NUMERICO:
          
$resultadoMetodo[] = array_values(get_object_vars($infoCampo));
          break;
          case 
TS_OBJETO:
          default:
            
$resultadoMetodo[] = $infoCampo;
            break;
      }
    }
     
    
// Liberamos los resultados de la consulta
    
@mysql_free_result($resultadoConsulta);   
       
    
// Y devolvemos el resultado del método
    
return $resultadoMetodo;     
  } 

Todo esto se puede ver funcionando en una nueva versión de la clase "bdatos.class" que acabo de actualizar. He hecho también algunos otros cambios que se detallan en el archivo "historial.txt". Para quien le interese, la clase puede descargarse desde aquí, mirar en el apartado "Código PHP".

kayetano 29-05-2006 11:48:53

Hola

¿Y por que no utilizar simplemente "mysql_fetch_array()" en vez de "mysql_fetch_filed()"?

dec 29-05-2006 12:25:31

Hola,

Cita:

Empezado por Kayetano
¿Y por que no utilizar simplemente "mysql_fetch_array()" en vez de "mysql_fetch_filed()"?

Porque si lo que se trata de conseguir es información sobre las columnas (campos) de una tabla "mysql_fetch_field" parece ser la solución propuesta por el manual de PHP sobre estos menesteres... Pero, dudo si estamos hablando de lo mismo Kayetano, discúlpame si eso.

Cita:

Empezado por PHP.net
mysql_fetch_array -- Fetch a result row as an associative array, a numeric array, or both

mysql_fetch_field -- Get column information from a result and return as an object


kayetano 29-05-2006 13:17:16

Hola

Yo lo digo por el proceso que está haciendo:
Código PHP:

    $resultadoConsulta mysql_query
      
("SELECT * FROM $tabla WHERE 0=1"$this->enlaceConexionBd);
        
    while (
$infoCampo mysql_fetch_field($resultadoConsulta)) 
    {      
      
$campo = array();
        
      
$campo['nombre']          = $infoCampo->name;
      
$campo['porDefecto']      = $infoCampo->def;
      
$campo['esBlob']          = $infoCampo->blob;
      
$campo['tipo']            = $infoCampo->type;
      
$campo['tabla']           = $infoCampo->table;
      
$campo['esNumerico']      = $infoCampo->numeric;
      
$campo['admiteNulos']     = $infoCampo->not_null;
      
$campo['sinSigno']        = $infoCampo->unsigned;
      
$campo['rellenoCeros']    = $infoCampo->zerofill;
      
$campo['maxLongitud']     = $infoCampo->max_length;
      
$campo['esClaveUnica']    = $infoCampo->unique_key;
      
$campo['esClavePrimaria'] = $infoCampo->primary_key;
      
$campo['claveMultiple']   = $infoCampo->multiple_key;
      
      
$resultadoMetodo[] = $campo;
    } 

Con "mysql_fetch_array()" no quedará igual pero si muy parecido:
Código PHP:

    $resultadoConsulta mysql_query
      
("SELECT * FROM $tabla WHERE 0=1"$this->enlaceConexionBd);
        
    while (
$infoCampo mysql_fetch_array($resultadoConsulta)) 
    {      
      
$resultadoMetodo[] = $infoCampo;
    } 

Ya digo que no es exactamente lo mismo pero si muy parecido.

dec 29-05-2006 14:43:49

Hola,

Ya comprendo por dónde querías ir Kayetano. En realidad podría utilizarse la función "mysql_fetch_assoc", con lo que ya nos quedaría un Array asociativo, mucho más "parecido" a lo que tenemos que el Array numérico que obtendríamos con "mysql_fetch_array".

En todo caso el tema estaba en "traducir" el objeto resultado de la función "mysql_fetch_field". De hecho ahora mismo en la clase BDatos de que venimos hablando no se utilizan Arrays, sino que se traduce el objeto, mejor dicho, las propiedades del objeto devuelto por la función "mysql_fetch_field" al español.

Para ello utilizo una clase auxiliar... pero no sé si fruto de mi ignorancia, de no ver otra forma de hacerlo, al menos de momento. El caso es que lo se pretendía conseguir era traducir los nombres de las propiedades del objeto mencionado.

Ahora mismo viene quedando el código fuente como se verá. Lo siguiente es el método que puede utilizarse para obtener información sobre las columnas (campos) de una determinada tabla de una base de datos:

Código PHP:

  /**
   * Devuelve información acerca de los campos de una
   * determinada tabla de la base de datos. El resul-
   * tado de este método puede consistir en un Array
   * de Objetos, un Array de Arrays asociativos o un
   * Array de Arrays numéricos.
   * 
   * @param string $tabla Nombre de la tabla
   * @return mixed array
   * @access public
   */
  
function Campos($tabla$tipoSalida TS_OBJETO
  {
    
// Comprobamos que se especifica una tabla
    
if(!isset($tabla) || $tabla == '')
      return 
false;
    
    
// Preparamos el resultado
    
$resultadoMetodo   = array();    
           
    
/* Nótese lo "mágico" de la consulta.
       (Gracias Román ;)
    */
    
$sql "SELECT * FROM $tabla WHERE 0 = 1";
    
    
/* ¿Porqué no utilizamos el método Consulta conque cuenta
       esta misma clase para obtener los resultados? La razón
       está en que el método Consulta no devuelve un "recurso"
       como lo hace "mysql_query", así que no podríamos luego
       utilizar el resultado más abajo, como se verá.
    */
    
$resultadoConsulta = @mysql_query($sql$this->enlaceConexionBd);
        
    
// ¿Algún error en la sala?
        
if(@mysql_error($this->enlaceConexionBd))
        {
            
$this->Error(@mysql_error($this->enlaceConexionBd));
            return 
false;
        }              

        
/* Es aquí donde necesitamos un resultado como el que nos
           devuelve la función "mysql_query", para utilizarlo en
           la función "mysql_fetch_field".
        */
    
while ($datosCampo = @mysql_fetch_field($resultadoConsulta)) 
    {            
      
/* Esto puede ser un poco estúpido. Lo único que
         nos ofrece la clase "InfoCampo" es un objeto
         cuyas propiedades son las mismas que el objeto
         que ahora contiene "$datosCampo". La diferencia
         está en que en el objeto "InfoCampo" sus propie-
         dades están en español. ¿Será esto útil?           
      */
      
$infoCampo = new InfoCampo($datosCampo);
      
      
/* A continuación toca mirar por el tipo de salida
         que se precisa, por defecto un Array de objetos,
         como en el resto de métodos de esta clase que
         devuelven datos.
      */
      
switch ($tipoSalida
      {
          case 
TS_ARRAY_ASOCIATIVO:
              
$resultadoMetodo[] = get_object_vars($infoCampo);
              break;
        case 
TS_ARRAY_NUMERICO:
          
$resultadoMetodo[] = array_values(get_object_vars($infoCampo));
          break;
          case 
TS_OBJETO:
          default:
            
$resultadoMetodo[] = $infoCampo;
            break;
      }
    }
     
    
// Liberamos los resultados de la consulta
    
@mysql_free_result($resultadoConsulta);   
       
    
// Y devolvemos el resultado del método
    
return $resultadoMetodo;     
  } 

Y, el objeto que obtenemos como resultado se conforma a partir de la clase "InfoCampo", que es esta lindeza de aquí:

Código PHP:

/**
 * 
 * @name InfoCampo
 * @access private
 * @package phpclasses
 * @version 0.1 26/5/2006
 * @author David Esperalta
 * @link mailto:[email protected]
 * 
 * @copyright 2006 David Esperalta
 * 
 */
class InfoCampo 
{
  
/**
   * Nombre del campo
   *
   * @var string
   * @access public
   * 
   */
  
var $nombre '';

  
/**
   * Nombre de la tabla
   *
   * @var string
   * @access public
   * 
   */  
  
var $tabla '';

  
/**
   * Valor por defecto
   *
   * @var string
   * @access public
   * 
   */    
  
var $porDefecto '';
  
  
/**
   * Máxima longitud
   *
   * @var integer
   * @access public
   * 
   */    
  
var $maxLogitud 0;

  
/**
   * ¿Admite valores nulos?
   *
   * @var integer
   * @access public
   * 
   */    
  
var $admiteNulos 0;

  
/**
   * ¿Es clave primaria?
   *
   * @var integer
   * @access public
   * 
   */    
  
var $esClavePrimaria 0;
  
  
/**
   * ¿Es clave única?
   *
   * @var integer
   * @access public
   * 
   */      
  
var $esClaveUnica 0;
  
  
/**
   * ¿Es clave múltiple?
   *
   * @var integer
   * @access public
   * 
   */      
  
var $esClaveMultiple 0;
  
  
/**
   * ¿Es de tipo numérico?
   *
   * @var integer
   * @access public
   * 
   */      
  
var $esNumerico 0;
  
  
/**
   * ¿Es de tipo "Blob"?
   *
   * @var integer
   * @access public
   * 
   */      
  
var $esBlob 0;

  
/**
   * Nombre del tipo
   *
   * @var string
   * @access public
   * 
   */      
  
var $tipo '';
  
  
/**
   * ¿Tiene signo?
   *
   * @var integer
   * @access public
   * 
   */      
  
var $sinSigno 0;
  
  
/**
   * ¿Se rellena con ceros?
   *
   * @var integer
   * @access public
   * 
   */
  
var $rellenoCeros 0;   
  
  
/**
   * Constructor de la clase
   *
   * El parámetro ha de ser un objeto del tipo
   * que devuelve la función "mysql_fech_field".
   * 
   * @param Object $datosCampo
   * @return InfoCampo
   * @access public
   * 
   */
  
function InfoCampo($datosCampo)
  {
    if(!isset(
$datosCampo))
      return 
null;
    else
      
$this->Cargar($datosCampo);  
    return 
true;
  }
  
  
/**
   * Traladamos las propiedades del objeto que
   * se pasa como parámetro a este propio objeto.
   * 
   * En realidad, como puede verse, lo único que
   * hacemos es "traducir" las propiedades del in-
   * glés al español.
   *
   * @param Object $datosCampo
   * @access private
   * 
   */
  
function Cargar($datosCampo)
  {
    
$this->nombre          $datosCampo->name;
    
$this->tabla           $datosCampo->table;
    
$this->porDefecto      $datosCampo->def;
    
$this->maxLogitud      $datosCampo->max_length;
    
$this->admiteNulos     $datosCampo->not_null;
    
$this->esClavePrimaria $datosCampo->primary_key;
    
$this->esClaveUnica    $datosCampo->unique_key;
    
$this->esClaveMultiple $datosCampo->multiple_key;
    
$this->esNumerico      $datosCampo->numeric;
    
$this->esBlob          $datosCampo->blob;
    
$this->tipo            $datosCampo->type;
    
$this->sinSigno        $datosCampo->unsigned;
    
$this->rellenoCeros    $datosCampo->zerofill;
  }

// class InfoCampo 


kayetano 29-05-2006 15:08:32

Hola

Cita:

Empezado por dec
Ya comprendo por dónde querías ir Kayetano. En realidad podría utilizarse la función "mysql_fetch_assoc", con lo que ya nos quedaría un Array asociativo, mucho más "parecido" a lo que tenemos que el Array numérico que obtendríamos con "mysql_fetch_array".

"mysql_fetch_array" proporciona un índice numérico y otro de texto con el nombre del campo, "mysql_fetch_row" es la función que solo proporviona un indice numérico.

dec 29-05-2006 15:13:54

Hola,

Bueno, tienes razón. De la ayuda para la función mysql_fetch_array:

Cita:

Empezado por Php.net
Returns an array that corresponds to the fetched row, or FALSE if there are no more rows. The type of returned array depends on how result_type is defined. By using MYSQL_BOTH (default), you'll get an array with both associative and number indices. Using MYSQL_ASSOC, you only get associative indices (as mysql_fetch_assoc() works), using MYSQL_NUM, you only get number indices (as mysql_fetch_row() works).


roman 29-05-2006 18:16:15

¿Me puede alguien explicar que tienen que ver las peras con las manzanas?

// Saludos

kayetano 29-05-2006 19:22:46

¿que son las peras y que son las manzanas?

dec 29-05-2006 19:29:40

Hola,

¿Alguien sabe por qué las peras y las manzanas cruzaron la carretera? Es que a lo visto hay un pollo que las está buscando. :D

Emilio 29-05-2006 19:30:12

Cita:

Empezado por kayetano
¿que son las peras y que son las manzanas?

Son dos tipos de culos, ambos de la clase TCulo claro, ya sabes, hay culos de pera, culos de manzaza y otros muchos tipos de culo, pega un vistazo a la ayuda.

Que se pretende con esa clase que se está haciendo ahí, no le veo gran utilidad.

Yo tambien suelo usar mysql_fetch_array me parece mucho más cómodo.

dec 29-05-2006 19:32:23

Hola,

Cita:

Empezado por Emilio
Que se pretende con esa clase que se está haciendo ahí, no le veo gran utilidad.

¿A qué clase se refiere usted caballero? :)

roman 29-05-2006 19:38:39

Cita:

Empezado por kayetano
¿que son las peras y que son las manzanas?

¿Qué tiene que ver mysql_fetch_field con mysql_fetch_array? El primero da información acerca de las columnas de una selección y el segundo nos da las filas de tal selección.


Cita:

Empezado por Emilio
Yo tambien suelo usar mysql_fetch_array me parece mucho más cómodo.

¿Más cómodo que qué cosa?

Insisto, ¿qué tiene que ver columnas con filas?

// Saludos

D-MO 29-05-2006 20:35:50

Cita:

Empezado por kayetano
Hola

¿Y por que no utilizar simplemente "mysql_fetch_array()" en vez de "mysql_fetch_filed()"?

compara los resultados kayetano, ambos son de la misma consulta:
Cita:

mysql_fetch_field:
stdClass Object ( [name] => id [table] => usuarios [def] => [max_length] => 1 [not_null] => 1 [primary_key] => 1 [multiple_key] => 0 [unique_key] => 0 [numeric] => 1 [blob] => 0 [type] => int [unsigned] => 0 [zerofill] => 0 )

mysql_fetch_array:
Array ( [0] => 1 [id] => 1 )
¿Es a caso lo mismo?

Saludos.


La franja horaria es GMT +2. Ahora son las 22:07:12.

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