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

C Discussion :

MySql.h Identifiant de colonne Id unsigned bigint


Sujet :

C

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Avril 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2017
    Messages : 3
    Par défaut MySql.h Identifiant de colonne Id unsigned bigint
    Bonjour,

    Je suis depuis un moment sur la conversion d'un bigint d'id d'enregistrement de MySql (mysql.h) vers un programme en C.
    Le programme me retourne un Id égale à 49 au lieu de 1 et 50 au lieu de 2, etc...

    Pourquoi ? quelqu'un aurait-il une idée?

    Code:
    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
     
    typedef struct Raspberry{
        unsigned int id;
        char hostname[20];
        char ip[15];
    } Raspberry;
     
    ...
     
    void query_raspi(Raspberry (*raspis)[255]) {
    ...
        while ((row = mysql_fetch_row(result)))
            {
                (*raspis)[i].id = (unsigned int)(*row)[0]; // --> renvoie 49 au lieu de 1
                sprintf((*raspis)[i].hostname, "%s", row[1]);
                sprintf((*raspis)[i].ip, "%s", row[2]);
                printf("%u %s %s\r\n", (*raspis)[i].id, (*raspis)[i].hostname, (*raspis)[i].ip);
                i++;
            }
            //Libération du jeu de résultat
            mysql_free_result(result);
     
    ....
    La tablea:
    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
    28
    29
    30
    31
    32
    33
    34
    35
     
    CREATE TABLE IF NOT EXISTS `raspi` (
    `id` bigint(20) unsigned NOT NULL,
      `hostname` varchar(50) NOT NULL,
      `ip` varchar(15) NOT NULL,
      `piece` varchar(50) NOT NULL
    ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1;
     
    --
    -- Contenu de la table `raspi`
    --
     
    INSERT INTO `raspi` (`id`, `hostname`, `ip`, `piece`) VALUES
    (1, 'raspberrypi', '192.168.1.240', 'chaufferie'),
    (2, 'RPI2B', '192.168.1.242', 'salon');
     
    --
    -- Index pour les tables exportées
    --
     
    --
    -- Index pour la table `raspi`
    --
    ALTER TABLE `raspi`
     ADD UNIQUE KEY `id_2` (`id`), ADD UNIQUE KEY `id_3` (`id`), ADD KEY `id` (`id`);
     
    --
    -- AUTO_INCREMENT pour les tables exportées
    --
     
    --
    -- AUTO_INCREMENT pour la table `raspi`
    --
    ALTER TABLE `raspi`
    MODIFY `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=4;
    Merci, Giamba

  2. #2
    Futur Membre du Club
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Avril 2017
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2017
    Messages : 3
    Par défaut Trouvé
    Bien voilà la solution, bonne ou pas je ne sais pas vraiment, mais ça fonctionne!

    MYSQL_ROW renvoie apparemment des "strings" donc une conversion atoi(row[0]) s'imposait.

    Merci à ceux qui auront jeté un œil à ma demande.

    Giamba

  3. #3
    Expert éminent

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 202
    Par défaut
    Le problème des entiers normaux, c'est qu'ils sont limités à un certains nombre de bits pour leur représentation binaire.
    Une possibilité est d'utiliser une chaine de caractères de longueur variable et potentiellement illimitée.

    Le soucis, c'est que c'est lourd, long et très délicat si la chaine contient une valeur plus grande que ce que la forme binaire permet.
    Par exemple, un entier non signé 64 bits peut monter jusqu'à 2^64 - 1. 2^70 n'est pas représentable en binaire, il faut donc procéder par morceaux. Les performances s'en ressentent.

    bigint ou big integer est le nom qu'on donne à cette technique.

    Je te recommande, si c'est possible d'utiliser un "simple" int (en mysql) et un long (en C) pour les identifiants de clés.

Discussions similaires

  1. Réponses: 4
    Dernier message: 23/01/2011, 22h36
  2. Identifier une colonNe ajoutée et/ou supprimer entre deux fichiers
    Par NewYork dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 23/12/2010, 13h53
  3. [MySQL] Requete MySQL et PHP en colonnes
    Par csrobe dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 19/10/2010, 07h45
  4. Réponses: 6
    Dernier message: 20/08/2010, 10h13
  5. MySQL : quote identifiers
    Par Jasmine80 dans le forum Requêtes
    Réponses: 6
    Dernier message: 10/03/2008, 12h54

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