Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 5 sur 5
  1. #1
    Futur Membre du Club
    Inscrit en
    mai 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : mai 2010
    Messages : 62
    Points : 17
    Points
    17

    Par défaut Erreur sqlalchemy lettre accentuée

    Bonjour,

    J'ai cette erreur qui survient à chaque appel de mes requêtes :

    Code :
    1
    2
    D:\Python26\lib\site-packages\sqlalchemy-0.7.3-py2.6.egg\sqlalchemy\engine\default.py:453: SAWarning: Unicode type received non-unicode bind param value
    param.append(processors[key](compiled_params[key]))
    Mes requêtes s'exécute bien si dans ma base il n'y a pas de lettre accentuée.

    Sa viendrais qu'elixir/sqlalchemy est en ASCII. savez-vous quel est le parametrage d'elixir/sqlalchemy pour qu'il soit en utf8 ?

    Je pense que c'est un paramètre qu'il faut écrire lors de la connection à la base.

    Cordialement

  2. #2
    Modérateur

    Homme Profil pro
    Architecte technique
    Inscrit en
    juin 2008
    Messages
    5 416
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : juin 2008
    Messages : 5 416
    Points : 8 178
    Points
    8 178

    Par défaut

    Salut,

    client encoding est un paramètre de la connexion à passer dans la construction de l'engine (ou de la metadata). Sa formulation dépend du type de la BDD voire du driver.

    - W
    Architectures Post-Modernes

  3. #3
    Futur Membre du Club
    Inscrit en
    mai 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : mai 2010
    Messages : 62
    Points : 17
    Points
    17

    Par défaut

    J'utilise une BDD de type Mysql, j'ai formulé ma connexion comme suite sachant que j'utilise elixir:

    Code :
    1
    2
    metadata.bind = "mysql://user:mdp@host/nomBDD"
    using_options_defaults(shortnames=True, convert_unicode=True, encoding="utf8")
    Mais rien ny fait ma BDD est bien créer, mais le warning est toujours là et du coup pas de possibilité de lire ou d'inserer des lettres accentuées.

    si vous avez l'écriture exacte de la connexion je suis preneuse.
    Merci

    Cordialement

  4. #4
    Modérateur

    Homme Profil pro
    Architecte technique
    Inscrit en
    juin 2008
    Messages
    5 416
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : juin 2008
    Messages : 5 416
    Points : 8 178
    Points
    8 178

    Par défaut

    Salut,

    Elixir est quelque peu devenu obsolete depuis que SQLAlchemy a intégré une interface declarative.
    MySQL est la BDD et non le driver DBAPI installé côté Python pour travailler avec.

    Dans la documentation du dialect MySQL, vous trouverez la façon de préciser "utf-8" en utilisant charset et use_unicode pour les différents "drivers".

    Bon courage,

    - W
    Architectures Post-Modernes

  5. #5
    Futur Membre du Club
    Inscrit en
    mai 2010
    Messages
    62
    Détails du profil
    Informations forums :
    Inscription : mai 2010
    Messages : 62
    Points : 17
    Points
    17

    Par défaut

    Bonjour wiztricks,

    J'avais bien lu cette doc et passée ma connection ainsi :

    Code :
    1
    2
    metadata.bind = "mysql://user:mdp@host/nomBDD"charset=utf8&use_unicode=0
    using_options_defaults(shortnames=True, convert_unicode=True, encoding="utf8")
    pas de résultat. Est ce que chaque class doit avoir le paramètre charset et unicode??
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    class Document_Hermione(Document, charset=utf8, unicode=0 ??):
        using_options(inheritance='multi', tablename = "Document_Hermione")
        Commentaire_DocH = Field (Unicode(255), nullable = False)
        BoolDocM = Field (Boolean, nullable = False)
        TypeDoc = ManyToOne ("Type_Doc")
        Attribution = OneToMany("Attribution")
        Nature = ManyToOne ("Nature_Doc")
        Etat = ManyToOne ("Etat_Doc")
        DocV=OneToMany("Doc_Version")

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

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •