IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Recherche du champ qui est Primary Key


Sujet :

PHP & Base de données

  1. #1
    Membre averti Avatar de XtofRoland
    Profil pro
    Inscrit en
    Août 2005
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2005
    Messages : 357
    Points : 392
    Points
    392
    Par défaut Recherche du champ qui est Primary Key
    une fonction de ma classe de connexion crée un formulaire a partir d'un select.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    function form(){
    		$fieldName  = array(); 
    	    $fieldLen  = array();
    	    $fieldType  = array();
    	    $fieldValue = array();
     
    	    $count = odbc_num_fields( $this->req )+1;
    		for ($i=1;$i<$count ;$i++){
    			$fieldName[$i] = odbc_field_name($this->req, $i);  // nom du champ
    		    $fieldLen[$i] = odbc_field_len($this->req, $i);   // longueur
    		    $fieldType[$i] = odbc_field_type($this->req, $i);         // type du champ
    		}
     
     
    		odbc_fetch_row($this->req);
    		for ($i=1;$i<$count ;$i++){
    			$fieldValue[$i] = "";
    			$fieldValue[$i] = odbc_result($this->req,$i);
    		}
    		$SQL = str_replace("from", "[*%&]", $SQL);
    		$SQL = str_replace("where", "[*%&]", $SQL);
    		list($fields,$table,$whereclause) = explode("[*%&]",$SQL);
     
     
    		$form = new form(serialize($fieldName), serialize($fieldLen), serialize($fieldType), serialize($fieldValue), $table );
    		return $form;
    	}
    dans le but d'automatiser un maximum, je cherche un moyen de trouver un max d'info:
    surtout quels sont les champs clefs primaires
    lesquels ont une contrainte unique
    eventuellement d'autres info ...
    la class form genere le sql d'update ou d'insert mais elle doit connaitre la clef primaire (pour le moment je l'ai hardcodé mais c'est pas tres "joli"...
    Merci d'avance.
    PS:je ne pense pas que ce soit une question sql
    J'ai trouvé une syntaxe "& PRI_KEY_FLAG" mais sans exemple d'utilisation.
    Le but de tout developpeur OO est de devenir une référence.
    Mon avatar est un ambigramme, les curieux peuvent le retourner ;-)
    Aider <> Faire a la place de!!!

  2. #2
    Membre éprouvé
    Inscrit en
    Juillet 2004
    Messages
    1 027
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 1 027
    Points : 1 164
    Points
    1 164
    Par défaut
    Le problème c'est que c'est peut être dépendant du SGBD sa.

    M'enfin voila une requete qui fonctionne sous mysql 5 et qui renvoie des trucs interessant :

    SHOW COLUMNS FROM maDb.Matable;
    SHOW INDEX FROM maDb.Matable;

    bye

  3. #3
    Membre averti Avatar de XtofRoland
    Profil pro
    Inscrit en
    Août 2005
    Messages
    357
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2005
    Messages : 357
    Points : 392
    Points
    392
    Par défaut
    C'est pas mal, et ca me reservira surement . Merci.
    mais c'est dépendant de la db...
    je cherche une facon generique de retrouver les clefs primaires.
    Le but de tout developpeur OO est de devenir une référence.
    Mon avatar est un ambigramme, les curieux peuvent le retourner ;-)
    Aider <> Faire a la place de!!!

  4. #4
    Rédacteur

    Avatar de Yogui
    Homme Profil pro
    Directeur technique
    Inscrit en
    Février 2004
    Messages
    13 721
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yonne (Bourgogne)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Février 2004
    Messages : 13 721
    Points : 29 985
    Points
    29 985
    Par défaut
    Salut

    J'ai malheureusement peur que ce soit DBMS-dependant...
    Peut-être le DESCRIBE tablename; est-il un peu plus courant ?

Discussions similaires

  1. Réponses: 1
    Dernier message: 06/10/2009, 10h06
  2. Réponses: 10
    Dernier message: 14/08/2007, 22h27
  3. comment savoir si une colonne est primary key d'une table?
    Par vinczente dans le forum Administration
    Réponses: 4
    Dernier message: 13/05/2007, 21h23
  4. Réponses: 3
    Dernier message: 18/07/2006, 10h17
  5. Ne pas afficher un champs qui est vide dans ma BD
    Par yoda_style dans le forum ASP
    Réponses: 3
    Dernier message: 27/04/2004, 11h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo