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

Shell et commandes GNU Discussion :

Génération script SQL


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut Génération script SQL
    Hello,
    j'ai en entrée, un fichier de la forme suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    COL1	COL2	COL3	COL4	COL5
    -96534749670000		04967Z	1	B		
    -97024749650000		04965Z	1	B
    Et je dois générer un script SQL pour insérer ces données.

    Le problème ici, c'est pour :

    • encadrer chaque valeur par des simples côtes
    • détecter la présence d'espace ou tabulation entre les valeurs pour déceler les colonnes "NULL" (ici la COL2 par exemple)



    Actuellement j'essaye avec quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    valeurs=$(echo $ligne | gawk '{gsub(" ", ",", $0);print valeurs=$0}')
    Sauf que là, il remplace n'importe quel espace par une virgule, du coup, la valeur vide de ma col2 passe à la trappe


    Il faudrait également que j'arrive à détecter pour chaque valeur si elle est de la forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    02/10/2012 04:44:27.000000 +00:00
    Pour la remplacer par un TO_DATE()




    Quelqu'un pour éclairer ma lanterne?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Quelle colonne peut être une date?
    Pour cette partie je n'ai pas d'idée pour le moment.

    Pour le reste voici une solution avec sed (c'est sans doute plus simple avec awk):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed "s/^/'/; s/\t/','/g; s/$/'/" fichier
    Chaque colonne sera encadrée par des simples quote.
    Les colonnes seront séparées par une virgule.

    Il reste à voir si c'est toujours séparé par des tabulations ou non.
    Et aussi s'il peut y en avoir dans le nom.

    Il faudrait aussi nous donner un exemple avec des espaces.

  3. #3
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Salut,

    si je fais un echo de cette commande, en effet, c'est pile ce que je veux.
    Mais si j'essaye cette commande sur une ligne, ca me met juste un simple cote en début et fin de ligne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    val=$(echo $ligne |sed "s/^/'/; s/\t/','/g; s/$/'/")
    Tu sais pourquoi?

    Pour les dates, justement c'est le problème, ça peut être n'importe laquelle suivant le fichier que je parse.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Il manquait un espace après la redirection. Si cela ne fonctionne toujours pas essaie avec la deuxième ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    val=$(echo $ligne | sed "s/^/'/; s/\t/','/g; s/$/'/")
    val=`echo $ligne | sed "s/^/'/; s/\t/','/g; s/$/'/"`

  5. #5
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Re,
    même résultat avec les deux lignes : juste une cote en début et fin de ligne.

  6. #6
    Invité
    Invité(e)
    Par défaut
    Peux-tu regarder si la ligne contient bien des tabulations?
    C'est peut être simplement des espaces contrairement à l'exemple que tu as mis plus haut.

  7. #7
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 342
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 342
    Par défaut
    Citation Envoyé par erox44 Voir le message
    Salut,

    si je fais un echo de cette commande, en effet, c'est pile ce que je veux.
    Mais si j'essaye cette commande sur une ligne, ca me met juste un simple cote en début et fin de ligne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    val=$(echo $ligne |sed "s/^/'/; s/\t/','/g; s/$/'/")
    Tu sais pourquoi?
    Bonjour,

    Juste pour la petite explication, il faut écrire echo "$ligne" pour que le echo conserve le format de $ligne.
    C'est le même principe que:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ echo  titi      tata      toto
    titi tata toto
    $ echo "titi      tata      toto"
    titi      tata      toto

  8. #8
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Ok merci de l'info

  9. #9
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Pour la partie traitement des dates,
    j'ai des données de la forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    '03/10/2012 01:26:18.000000 +00:00'
    C'est quoi le moyen le plus simple de transformer cette chaine en l'encadrant par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    to_timestamp_tz('$donnee','dd-mm-yyyy hh24:mi:ss TZH:TZM')
    La regex devrait ressembler à ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [0-9]{1,2}\/[0-9]{1,2}\/[0-9]{4} [0-9]{2}:[0-9]{2}:[0-9]{2}.[0-9]{6} \+[0-9]{2}:[0-9]{2}

  10. #10
    Invité
    Invité(e)
    Par défaut
    Tu as un peu de retard sur disedorgue
    Citation Envoyé par disedorgue Voir le message
    Bonjour,

    Juste pour la petite explication, il faut écrire echo "$ligne" pour que le echo conserve le format de $ligne.
    C'est le même principe que:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ echo  titi      tata      toto
    titi tata toto
    $ echo "titi      tata      toto"
    titi      tata      toto

  11. #11
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par ecatomb Voir le message
    Tu as un peu de retard sur disedorgue
    C'est pas faux!!!
    J'avais pô bien lu les réponses

  12. #12
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par erox44 Voir le message
    si je fais un echo de cette commande, en effet, c'est pile ce que je veux.
    Mais si j'essaye cette commande sur une ligne, ca me met juste un simple cote en début et fin de ligne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    val=$(echo $ligne |sed "s/^/'/; s/\t/','/g; s/$/'/")
    Tu sais pourquoi?
    Oui. Je sais pourquoi.
    C'est parce que tu n'as pas respecté la règle que je préconise habituellement:
    toujours entourer les variables de double-quotes (sauf si raison valable bien comprise!)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $ echo "$line" | od -c
    0000000    -   9   6   5   3   4   7   4   9   6   7   0   0   0   0  \t
    0000020   \t   0   4   9   6   7   Z  \t   1  \t   B  \t  \t  \n    
     
    $ echo $line | od -c
    0000000    -   9   6   5   3   4   7   4   9   6   7   0   0   0   0    
    0000020    0   4   9   6   7   Z       1       B  \n
    CQFD

  13. #13
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    De retour,
    mon script fonctionne très bien quand je le teste via Cygwin, mais là où c'est moins cool, c'est quand je le lance sur le serveur Solaris, les traitements ne sont plus les mêmes

    n'est plus reconnu
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed "s/'/''/g; s/\t/','/g" $nomFic
    le \t n'est pas trouvé.

    Et plus bas dans le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ligne4=$(echo "$ligne3" | sed "s#'[0-9]\{1,2\}/[0-9]\{1,2\}/[0-9]\{4\} [0-9]\{2\}:[0-9]\{2\}:[0-9]\{2\}'#to_date(\0 ,'dd/mm/yyyy hh24:mi:ss')#g")
    la partie \0 me renvoie non plus la chaine traitée, mais tout simplement la chaine "0"

    Pour qu'une partie passe j'ai modifié :
    en

  14. #14
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    La version de sed sur Solaris n'est pas GNU (comme Cygwin) mais POSIX
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  15. #15
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Ok donc il y a un impact sur le sed en lui même ainsi que les regex d'après Google

    Ce qui m'étonne là c'est que, je balances ces commandes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -e "s/'/''/g; s/	/','/g" $nomFic > tempo.txt
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    colonnes=$(echo "$ligne" | nawk '{gsub("\047", "", $0);print colonnes=$0}')
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    			#on transforme les timestamp par la fonction oracle TO_TIMESTAMP_TZ()
    			ligne3=$(echo "$ligne" | sed "s#\('[0-9]\{1,2\}/[0-9]\{1,2\}/[0-9]\{4\} [0-9]\{2\}:[0-9]\{2\}:[0-9]\{2\}\)\.[0-9]\{6\} \(+[0-9]\{2\}:[0-9]\{2\}'\)#to_timestamp_tz(\1 \2,'dd/mm/yyyy hh24:mi:ss TZH:TZM')#g")
    			ligne4=$(echo "$ligne3" | sed "s#'[0-9]\{1,2\}/[0-9]\{1,2\}/[0-9]\{4\} [0-9]\{2\}:[0-9]\{2\}:[0-9]\{2\}'#to_date(\0 ,'dd/mm/yyyy hh24:mi:ss')#g")
    			ligne5="'${ligne4}'"
     
    			echo "insert into ${nomTable} (${colonnes}) values ( ${ligne5}, to_date('${dateTechnique}', 'dd/mm/yyyy hh24:mi:ss') );" >> tmp.txt
    Je concatène le tout, et pourtant , il me rajoute des retour chariots à gogo, et si impossible de les virer :/

  16. #16
    Invité
    Invité(e)
    Par défaut
    Passe un coup de dos2unix sur tes fichiers avant de lancer le programme. Ca va enlever le caractère de retour chariot en trop (celui de windows)

  17. #17
    Membre éclairé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2007
    Messages
    500
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Avril 2007
    Messages : 500
    Par défaut
    Hm je viens de lancer la commande sur mes fichiers avant de les transferer sur mon serveur, j'ai relancé mon script:

    les fichiers générés sont maintenant sans les retours chariot

    par contre la ligne suivante semble encore poser soucis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ligne4=$(echo "$ligne3" | sed "s#'[0-9]\{1,2\}/[0-9]\{1,2\}/[0-9]\{4\} [0-9]\{2\}:[0-9]\{2\}:[0-9]\{2\}'#to_date(\0 ,'dd/mm/yyyy hh24:mi:ss')#g")
    Dans mon fichier généré au lieu du param \0 j'ai la chaine "0"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ..., to_date(0 ,'dd/mm/yyyy hh24:mi:ss', ...
    Pourtant la ligne suivante fonctionne nickel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ligne3=$(echo "$ligne" | sed "s#\('[0-9]\{1,2\}/[0-9]\{1,2\}/[0-9]\{4\} [0-9]\{2\}:[0-9]\{2\}:[0-9]\{2\}\)\.[0-9]\{6\} \(+[0-9]\{2\}:[0-9]\{2\}'\)#to_timestamp_tz(\1 \2,'dd/mm/yyyy hh24:mi:ss TZH:TZM')#g")

    Vous auriez une idée?

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

Discussions similaires

  1. génération script sql
    Par zoheir13 dans le forum Firebird
    Réponses: 2
    Dernier message: 26/12/2010, 10h41
  2. Génération automatique de script SQL
    Par Prjprj dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 07/11/2007, 15h35
  3. Power AMC, génération script SQL
    Par davasm dans le forum PowerAMC
    Réponses: 1
    Dernier message: 24/05/2006, 16h18
  4. [PAMC]génération d'un mcd à partir d'un script sql
    Par jounaidi dans le forum Sybase
    Réponses: 2
    Dernier message: 27/03/2006, 17h43
  5. Génération de script SQL avec les données
    Par borgfabr dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 05/03/2004, 13h57

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