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

Python Discussion :

Replace sans Upper/Lower


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 186
    Par défaut Replace sans Upper/Lower
    Bonjour,

    Je cherche à remplacer une chaine de caractères #toto# dans un ordre SQL que je ne peux pas convertir en majuscules ou minuscules (à cause par exemple de l'utilisation de "format").
    exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select #toto# from LaTable where format(LaDate, 'yyyyMM') = format(getdate()-1, 'yyyyMM')
    Et forcément, je peux avoir #toto# ou #Toto# ou autres joyeusetés.
    Quelqu'un aurait-il une solution ?
    Merci
    [Access] Les bases du débogage => ici

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 744
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 744
    Par défaut
    Salut

    Dans "SELECT #toto# FROM...", #toto# est le nom d'un des champs de la table (ce n'est pas une variable). Du coup, difficile de comprendre ce que vous cherchez à faire.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre Expert

    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 186
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 186
    Par défaut
    Il s'agit d'un exemple, mais l'idée est de remplacer #toto# par un nom de champ (ou une variable dans la clause where : where LeChamp = #toto#)
    #toto# peut donc valoir 2, titi, 'tut', '2023-12-21', ...
    Mais malheureusement, #toto#peut être écrit #Toto#, #TOTO#, #ToTo#, ...
    [Access] Les bases du débogage => ici

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 744
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 744
    Par défaut
    Citation Envoyé par Kloun Voir le message
    Il s'agit d'un exemple, mais l'idée est de remplacer #toto# par un nom de champ (ou une variable dans la clause where : where LeChamp = #toto#)
    Dans une requête SQL il y a la partie chaine de caractères et la partie données où il faudra convertir un type python en type de la colonne de la table.

    Du coup, on ne va pas remplacer le xyz d'un "SELECT xyz" de la même façon que le xyz dans "WHERE le_champ=xyz" (et côté Python, on va utiliser d'autres moyens).

    Tout ça est expliqué dans la documentation de sqlite3 qui est la référence de l'API Python pour les bases de données (i.e. interface utilisée aussi par les autres SGDB-R)

    Normalement quand vous venez ici, vous êtes supposé avoir ouvert un tuto., lu la documentation, histoire d'utiliser un vocabulaire technique compréhensible (ça aide de savoir de quoi qu'on cause!).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 972
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 2 972
    Par défaut
    S'il s'agit de remplacer le nom d'une colonne :
    Comme la plupart des SGBS ne sont pas sensible à la casse lorsqu'il s'agit de nom de colonnes, il n'y pas nécessairement de raison de s'en soucier.
    Et si les nom des colonnes sont sensible à la casse, il est toujours possible d'établir un dictionnaire dont la clé est le nom de la table en minuscule et où la valeur est le véritable nom de la table.

    Sil s'agit de remplacer une valeur texte dans une clause WHERE :
    La plupart des SGBD possède des routines pour minimiser ou maximiser une valeur.
    Exemple avec SQLite :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM mytable 
    WHERE UPPER(myfield) like 'G2%'

  6. #6
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 835
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par popo Voir le message
    Comme la plupart des SGBS ne sont pas sensible à la casse lorsqu'il s'agit de nom de colonnes,
    Postgres, lui, il l'est. Mais cela dépend aussi de la façon de nommer les choses. Si par exemple on crée une table create table "Facture" (...) la table se nommera "Facture". Si maintenant on la crée dans cette syntaxe create table Facture (...) la table se nommera "facture". Et il en va de même avec les noms des colonnes, vues, index, fonctions et autres.

    Citation Envoyé par popo Voir le message
    il n'y pas nécessairement de raison de s'en soucier.
    Là je suis plus réservé. C'est quand-même un détail assez important...

    Citation Envoyé par popo Voir le message
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM mytable 
    WHERE UPPER(myfield) like 'G2%'
    Cela fait perdre l'avantage des index. S'il y a un index sur "myfield", il ne sera pas pris en compte.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  7. #7
    Expert confirmé
    Avatar de fred1599
    Homme Profil pro
    Lead Dev Python
    Inscrit en
    Juillet 2006
    Messages
    4 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Lead Dev Python
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2006
    Messages : 4 062
    Par défaut
    Bonjour,

    Quel est le rapport avec Python ? En plus on ne voit pas de code Python...

    Si vous souhaitez utiliser une fonction SQL de remplacement dans votre requête SQL, il faudrait connaître votre SGBD, car cela peut varier concernant la solution à employer.

    Ce que vous essayez de faire peut-être, car je trouve votre prose pas très compréhensible, c'est d'utiliser une variable python dans une requête SQL qui serait placée à l'endroit où se trouve #toto# ?

    Pour PostgreSQL ou MySQL ou SQLite3

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    requete_sql = "SELECT %s FROM LaTable WHERE format(LaDate, 'yyyyMM') = format(getdate()-1, 'yyyyMM')"
    cursor.execute(requete_sql, (colonne,))

Discussions similaires

  1. [11gR1] Création index sur replace(lower(colonne), ' ')
    Par strompakha dans le forum SQL
    Réponses: 2
    Dernier message: 30/01/2014, 22h00
  2. Réponses: 7
    Dernier message: 01/11/2007, 13h25
  3. [String] replace sans la casse
    Par zaoueche dans le forum Langage
    Réponses: 6
    Dernier message: 27/04/2006, 15h42
  4. MDI sans MFC, possible ?
    Par delire8 dans le forum MFC
    Réponses: 4
    Dernier message: 17/06/2002, 07h38
  5. [Kylix] Fiches sans bordure
    Par alex dans le forum EDI
    Réponses: 4
    Dernier message: 28/04/2002, 21h19

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