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

Langage SQL Discussion :

Insert into avec select et concat


Sujet :

Langage SQL

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut Insert into avec select et concat
    Bonjour,

    J'ai un problème pour exécuter le code suivant sur phpmyadmin :

    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
    INSERT INTO matable (id,diff)
    select 
        formulaire.id,
        DATEDIFF((
        select 
        ( STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d') ) as ticket 
        from commentaires
        where commentaires.Idcomment = formulaire.id
        order by commentaires.id desc
        limit 1
       ), STR_TO_DATE(CONCAT (formulaire.annee, '-', formulaire.mois, '-', formulaire.jour), '%Y-%m-%d')
       )
    from
        formulaire
        where 
        formulaire.annee='2013' and formulaire.mois='7'

    J'obtiens l'erreur suivante :
    #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '(commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d'' at line 7
    Pourtant, la requête sans le insert into fonctionne parfaitement et de même, j'arrive à faire un insert into sans concat dedans...
    Je ne comprends vraiment pas d'où cela peut venir.

    Merci d'avance pour votre aide!

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Le SELECT a 3 colonnes, le INSERT INTO que 2...

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Non le select a seulement 2 colonnes : formulaires.id et le datediff....

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    91
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 91
    Points : 70
    Points
    70
    Par défaut
    Je m'y connais pas trop en manipulation de date désolé. Mais à quoi sert le "AS ticket" dans la ligne 6

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Oui il ne sert à rien c'est vrai, j'ai déjà essayé avec ou sans, le résultat est le même!

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    91
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 91
    Points : 70
    Points
    70
    Par défaut
    EDIT : J'ai écris une bétise

    Je recherche je te tiens au courant

  7. #7
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    91
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 91
    Points : 70
    Points
    70
    Par défaut
    Essai ça :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    INSERT INTO matable (id,diff)
    SELECT 
        formulaire.id,
        DATEDIFF((
        SELECT STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d')
        FROM commentaires
        WHERE commentaires.Idcomment = formulaire.id
        ORDER BY commentaires.id DESC
        LIMIT 1
       ), STR_TO_DATE(CONCAT (formulaire.annee, '-', formulaire.mois, '-', formulaire.jour), '%Y-%m-%d')
       )
    FROM
        formulaire
        WHERE 
        formulaire.annee='2013' AND formulaire.mois='7'

    Sinon test la requête voir si elle fonctionne toute seule :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d')
        FROM commentaires
        WHERE commentaires.Idcomment = formulaire.id
        ORDER BY commentaires.id DESC
        LIMIT 1

    Si c'est le cas test cella la :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT 
        DATEDIFF((
        SELECT STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d')
        FROM commentaires
        WHERE commentaires.Idcomment = formulaire.id
        ORDER BY commentaires.id DESC
        LIMIT 1
       ), STR_TO_DATE(CONCAT (formulaire.annee, '-', formulaire.mois, '-', formulaire.jour), '%Y-%m-%d')
       )
    FROM
        formulaire

    Et dit moi ce que ça donne. Ca va permettre d'isolé un peu le probleme.

  8. #8
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Merci de ton aide en tout cas!

    Pour tout te dire, j'ai réussi en contournant totalement le problème (changement de langage) mais j'ai quand même envie de comprendre le problème !

    Alors les 2 premières requêtes échouent, avec le même message d'erreur que dans mon premier post.
    Par contre ta 3ème requête fonctionne bien. Je n'y comprends vraiment rien!

    De plus, la requête suivante fonctionne :
    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
     
    SELECT 
        formulaire.id,
        DATEDIFF((
        SELECT 
        ( STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d') ) AS ticket 
        FROM commentaires
        WHERE commentaires.Idcomment = formulaire.id
        ORDER BY commentaires.id DESC
        LIMIT 1
       ), STR_TO_DATE(CONCAT (formulaire.annee, '-', formulaire.mois, '-', formulaire.jour), '%Y-%m-%d')
       )
    FROM
        formulaire
        WHERE 
        formulaire.annee='2013' AND formulaire.mois='7'
    Alors je ne vois pas pourquoi en mettant un insert into, il arrive à me trouver une erreur dans la requête... (peut-être est-ce impossible de faire un concat dans un insert into ?!)

  9. #9
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut,
    Quel est le type de matable.diff ?

  10. #10
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Hello!
    A la base, il est de type Int et j'ai aussi essayé en le mettant de type Char.

  11. #11
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    T'as essayé de remplacer "( STR_TO_DATE(CONCAT (commentaires.annee, '-', commentaires.mois, '-', commentaires.jour), '%Y-%m-%d') ) AS ticket"
    par current_timestamp (par exemple) pour voir si c'est vraiment ça qui est en cause ?

  12. #12
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Oui, en remplaçant les deux STR_TO_DATE, cela fonctionne. C'est pour cela que je pense qu'il y a un problème de compatibilité INSERT/CONCAT mais je ne vois pas pourquoi...

  13. #13
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    C'est peut être une erreur à l'exécution (et non de syntaxe), genre t'as une donnée pourrie qui ne correspond pas à une date.

    T'as essayé de mettre ça ?
    ( STR_TO_DATE(CONCAT ('2013', '-', '07', '-', '18'), '%Y-%m-%d') ) AS ticket

  14. #14
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    Voilà l'erreur que j'obtiens dans ce cas :

    #1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '('2013', '-', '07', '-', '18'), '%Y-%m-%d') ) AS ticket
    FROM commentaires
    ' at line 6
    Il pointe donc toujours le CONCAT...

  15. #15
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Et
    ( STR_TO_DATE('2013-07-18', '%Y-%m-%d') ) AS ticket
    ?

  16. #16
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    91
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 91
    Points : 70
    Points
    70
    Par défaut
    Il en faudrai pas mettre plutot
    SELECT ( STR_TO_DATE('2013-07-18'), '%Y-%m-%d') ) AS ticket


    car j'ai eu la meme erreur sans mettre de select (le message édité et supprimer)

  17. #17
    Nouveau Candidat au Club
    Homme Profil pro
    Etudiant
    Inscrit en
    Juillet 2013
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juillet 2013
    Messages : 8
    Points : 1
    Points
    1
    Par défaut
    En faisant des STR_TO_DATE sans concat, je n'ai plus d'erreur effectivement.

    Bon je pense que je vais abandonner puisque j'ai l'impression qu'il sera difficile de trouver une explication plausible à ce problème.

    Merci beaucoup pour votre aide quand même!

Discussions similaires

  1. [AC-2003] insert into avec select sur colonne suivante
    Par nawakbling dans le forum VBA Access
    Réponses: 1
    Dernier message: 12/10/2010, 19h44
  2. [AC-2002] Requête INSERT INTO avec SELECT et VALUES
    Par chim33 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 10/03/2010, 16h45
  3. [REQUETE] Question requete 'insert into' avec select
    Par Jeannot dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 09/08/2007, 17h52
  4. Probleme avec INSERT INTO et select
    Par jmjmjm dans le forum Requêtes
    Réponses: 9
    Dernier message: 28/01/2007, 22h51
  5. [Débutant] INSERT INTO avec VALUES + SELECT
    Par Feezdev dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 15/06/2006, 10h10

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