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

Requêtes MySQL Discussion :

select, if vs utf8


Sujet :

Requêtes MySQL

  1. #1
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Serbie

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 42
    Points : 55
    Points
    55
    Par défaut select, if vs utf8
    Salut!

    Si une table existe dans un format de UTF8 et on utilise SELECT avec IF, on arrive sur un problème intéressant.

    Alors, on définit une table avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    CREATE TABLE person
    (
      id INT AUTO_INCREMENT PRIMARY KEY,
      name VARCHAR(16)
    ) DEFAULT CHARSET="utf8"
    et on ajoute une ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    INSERT INTO person(name) VALUES('Petrović')
    Si on exécute un requête de Perl ou Python script comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT IF(name != '', name, id) FROM person
    le résultat n'est pas encodé en UTF8 mais en ASCII. Si on exécute le même requête avec IF "cast"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT IF(name != '', name, CAST(id AS CHAR(4))) FROM person
    on obtient le résultat encodé en UTF8.
    Les requêtes sont exécutes par les scripts en Perl et Python, je me suis pas encore les essayés par les exécuter en C.
    Est-ce que c'est un problème de SQL (encodage ou "colations" de charsets), un problème de librarie client de C ou quelque autre chose? J'ai utilisé MySQL 5.1.41 et 5.1.38 64bit.
    Voilà de code en Perl qui illustre le problème.
    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
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
     
    #!/usr/bin/perl
     
     
    use lib "/usr/local/perl5/cpan/DBD-mysql-4.013/lib64/perl5/site_perl/5.10.0/x86_64-linux-thread-multi";
    use DBI;
     
     
    my $status = undef;
     
    my $dbh = DBI->connect("DBI:mysql:database=test;host=localhost", "karas");
    if (!defined($dbh))
    {
         printf STDERR "cannot connect to database!\n";
         exit(1);
    }
     
    $status = $dbh->do("DROP TABLE IF EXISTS person");
    if (!defined($status))
    {
         printf STDERR "cannot drop 'person' table\n";
    }
     
    $status = $dbh->do('CREATE TABLE person(id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(16)) DEFAULT CHARSET="utf8"');
    if (!defined($status))
    {
         printf STDERR "cannot create 'person' table\n";
    }
     
    $status = $dbh->do("INSERT INTO person(name) VALUES('Petrović')");
    if (!defined($status))
    {
         printf STDERR "cannot insert into 'person' table!\n";
    }
     
    #$sth = $dbh->prepare("SELECT IF(name != '', name, id) FROM person");
    #$sth = $dbh->prepare("SELECT name FROM person");
    $sth = $dbh->prepare("SELECT IF(name != '', name, CAST(id AS CHAR(4))) FROM person");
    if (defined($sth))
    {
         $status = $sth->execute;
         if (defined($status))
         {
              while (@row = $sth->fetchrow_array)
              {
                   print "@row\n";
              }
         }
         else
         {
              printf STDERR "cannot execute select for 'person' table!\n";
         }
    }
    else
    {
         printf STDERR "cannot prepare select for 'person' table!\n";
    }

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 281
    Points : 11 737
    Points
    11 737
    Par défaut
    Que donne la requête suivante, quand tu la passes à travers Perl ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CHARSET(id), CHARSET(IF(1 = 1, id, id)) FROM person LIMIT 1
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  3. #3
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Serbie

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 42
    Points : 55
    Points
    55
    Par défaut
    Je me reçois
    comme la réponse. Donc, je dois utiliser la connexion de UTF8, n'est-ce pas?

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 281
    Points : 11 737
    Points
    11 737
    Par défaut
    La connexion je ne pense pas, mais le jeu de caractères, oui, Tu peux utiliser par exemple CONVERT(id USING utf8).
    Antoun
    Expert Essbase, BO, SQL

    La bible d'Essbase, 2ème édition

  5. #5
    Membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Serbie

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2008
    Messages : 42
    Points : 55
    Points
    55
    Par défaut
    Il paraît que Perl n'ajoute pas UTF8 dans le tableau person comme il faut. Si on ajoute les caractères UTF8 directement ou par l'autre program écrit par exemple en C++/Qt, et donc je lis le même ligne avec cette application en Perl, le probleme disparaît.
    Je declare le problème comme résolu, si quelqu'un a besoin de C++/Qt code correct, je peux le donner ici.
    Merci pour l'aide.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Multi-selection dans une ComboBox ?
    Par Moloko dans le forum MFC
    Réponses: 5
    Dernier message: 07/07/2021, 17h26
  2. [VB6] [Crystal] Selection enregistrement
    Par littlecow dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/01/2005, 13h08
  3. SELECT
    Par Thomad dans le forum SQL
    Réponses: 2
    Dernier message: 13/03/2003, 20h56
  4. TEdit : selection du texte et autre fonction
    Par Odulo dans le forum Composants VCL
    Réponses: 5
    Dernier message: 01/08/2002, 14h27
  5. faire un selection dans une image aves les APIs
    Par merahyazid dans le forum C++Builder
    Réponses: 3
    Dernier message: 30/04/2002, 10h44

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