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

SQL Oracle Discussion :

Update avec MIN() conditionnel


Sujet :

SQL Oracle

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut Update avec MIN() conditionnel
    Salut,
    je désire mettre à jour une colonne dans Oracle à partir d'un calcul MIN() d'une date. Rien de compliqué mais je n'arrive pourtant pas à trouver la bonne syntaxe.
    Pour faire simple, j'ai 2 tables T1 et T2 avec comme champs :
    PO : Clé primaire
    DT : Date

    Je veux mettre à jour T1 avec le MIN (DT) de T2, uniquement si la date est différente.

    Exemples :
    T1 :
    1 | 15/01/2012
    2 | 30/03/2012
    3 | 01/05/2012

    T2 :
    1 | 10/01/2012
    1 | 15/01/2012
    2 | 30/03/2012
    2 | 14/04/2012

    Résultats attendus dans T1 : 1 update de la première ligne
    1 | 10/01/2012
    2 | 30/03/2012
    3 | 01/05/2012

    J'ai fait ça comme requête mais je n'ai que des update (les 3 lignes) à NULL et je ne vois pas pourquoi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    UPDATE T1 set dt = 
       (
           SELECT 
             MIN_DT 
           FROM (SELECT PO, MIN (DT) AS MIN_DT
                 from T2 RCL
                 GROUP BY PO
                ) A
           WHERE T1.PO = A.PO
                 AND T1.DT != A.MIN_DT
        );
    Cette autre solution fonctionne et j'update avec la bonne valeur mais sur toutes les lignes même si la date est bonne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    UPDATE T1 set dt = 
       (
           SELECT 
             MIN(DT) AS MIN_DT
           FROM (SELECT PO, DT
                 from T2
                ) A
           WHERE T1.PO = A.PO
        )
    ;
    J'ai bien une autre solution qui fonctionne mais en ayant un WHERE sur l'update avec une sous requête dans laquelle je recalcule le MIN() donc c'est pas top et j'imagine qu'on peut faire plus optimisé.

    Merci pour votre aide !

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Quelle est votre version d'Oracle ?

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Oracle 9 ou 10, ça dépend des environnements.

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    En 10g :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    MERGE INTO T1
    USING ( SELECT PO, MIN (DT) AS MIN_DT
              FROM T2
          GROUP BY PO)  T2
       ON (T1.PO = T2.PO)
     WHEN MATCHED THEN UPDATE
      SET T1.DT =  T2.MIN_DT
    WHERE T1.DT <> T2.MIN_DT;

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Waldar Voir le message
    En 10g :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    MERGE INTO T1
    USING ( SELECT PO, MIN (DT) AS MIN_DT
              FROM T2
          GROUP BY PO)  T2
       ON (T1.PO = T2.PO)
     WHEN MATCHED THEN UPDATE
      SET T1.DT =  T2.MIN_DT
    WHERE T1.DT <> T2.MIN_DT;
    J'obtiens un ORA-00905 Missing keyword. Une question de version d'Oracle ?

  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Probablement. Vous avez testé sur la 10g ?

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Probablement. Vous avez testé sur la 10g ?
    Testé en 11 et ça fonctionne. Mais j'ai une DB en v9 donc ça va poser un souci cette syntaxe.

  8. #8
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    Avez tenté ce genre de chose :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    UPDATE
      T1
    SET DT= (SELECT Case WHEN T1.DT<> ST2.DT THEN T1.DT ELSE ST2.DT END
    FROM
    (SELECT T2.PO as PO , MIN(DT) as DT FROM T2
       GROUP BY T2.PO) ST2
    WHERE T1.PO = ST2.PO)
    A adapter et a tester, bien evidemment.
    Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)

  9. #9
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Citation Envoyé par ctiguidou Voir le message
    Testé en 11 et ça fonctionne. Mais j'ai une DB en v9 donc ça va poser un souci cette syntaxe.
    En 9i il faut ruser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    MERGE INTO T1
    USING ( SELECT PO, MIN (DT) AS MIN_DT
              FROM T2
             WHERE PO IN (SELECT PO FROM T1)
          GROUP BY PO)  T2
       ON (T1.PO = T2.PO)
     WHEN MATCHED THEN UPDATE
      SET T1.DT =  T2.MIN_DT
    WHERE T1.DT <> T2.MIN_DT
     WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
    Mais si vous aviez cherché vous l'auriez surement trouvé tout seul.

  10. #10
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Yanika_bzh Voir le message
    Avez tenté ce genre de chose :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    UPDATE
      T1
    SET DT= (SELECT Case WHEN T1.DT<> ST2.DT THEN T1.DT ELSE ST2.DT END
    FROM
    (SELECT T2.PO as PO , MIN(DT) as DT FROM T2
       GROUP BY T2.PO) ST2
    WHERE T1.PO = ST2.PO)
    A adapter et a tester, bien evidemment.
    Oui ça fonctionne mais ça met à jour toute la table et non pas uniquement celles dont la date est différente du MIN().

  11. #11
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Waldar Voir le message
    En 9i il faut ruser :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    MERGE INTO T1
    USING ( SELECT PO, MIN (DT) AS MIN_DT
              FROM T2
             WHERE PO IN (SELECT PO FROM T1)
          GROUP BY PO)  T2
       ON (T1.PO = T2.PO)
     WHEN MATCHED THEN UPDATE
      SET T1.DT =  T2.MIN_DT
    WHERE T1.DT <> T2.MIN_DT
     WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
    Mais si vous aviez cherché vous l'auriez surement trouvé tout seul.
    Ben j'ai cherché et ce que j'ai trouvé c'est que le MERGE conditionnel a été introduit avec Oracle 10, donc ce qui coince ici c'est l'avant dernière ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE T1.DT <> T2.MIN_DT
    Si je l'enlève ça fonctionne mais du coup je perds la condition.

  12. #12
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

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

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Déplacez le filtre du Where dans un Case
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ...
      Set T1.DT =  Case When T1.DT <> T2.MIN_DT Then T2.MIN_DT Else T1.DT End
    ...

  13. #13
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Déplacez le filtre du Where dans un Case
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ...
      Set T1.DT =  Case When T1.DT <> T2.MIN_DT Then T2.MIN_DT Else T1.DT End
    ...
    Oui mais avec cette syntaxe j'aurai un update pour toutes les lignes quand même alors que je ne veux updater que celles avec une date différente. C'est une question de volumétrie, j'ai quelques centaines de lignes à mettre à jour parmi plusieurs millions et hors de question de faire un update massif donc.

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

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    En modifiant la requête du USING pour ne sélectionner que les lignes que l'on souhaite modifier c'est possible :
    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
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 15/01/12
             2 30/03/12
             3 01/05/12
     
    SQL> select * from t2;
     
            PO DT
    ---------- --------
             1 10/01/12
             1 15/01/12
             2 30/03/12
             2 14/04/12
             4 14/04/12
     
    SQL> SELECT PO, MIN (DT) AS MIN_DT
      2    FROM T2
      3   GROUP BY PO
      4  having min(dt) <> (select dt from t1 where t1.po = t2.po);
     
            PO MIN_DT
    ---------- --------
             1 10/01/12
     
    SQL> MERGE INTO T1
      2  USING ( SELECT PO, MIN (DT) AS MIN_DT
      3            FROM T2
      4           GROUP BY PO
      5          having min(dt) <> (select dt from t1 where t1.po = t2.po)
      6        )  T
      7     ON (T1.PO = T.PO)
      8   WHEN MATCHED THEN UPDATE
      9    SET T1.DT =  T.MIN_DT
     10   WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
     
    1 row merged.
     
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 10/01/12
             2 30/03/12
             3 01/05/12
     
    SQL>
    Mais est ce correct niveau perf ?

  15. #15
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par skuatamad Voir le message
    En modifiant la requête du USING pour ne sélectionner que les lignes que l'on souhaite modifier c'est possible :
    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
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 15/01/12
             2 30/03/12
             3 01/05/12
     
    SQL> select * from t2;
     
            PO DT
    ---------- --------
             1 10/01/12
             1 15/01/12
             2 30/03/12
             2 14/04/12
             4 14/04/12
     
    SQL> SELECT PO, MIN (DT) AS MIN_DT
      2    FROM T2
      3   GROUP BY PO
      4  having min(dt) <> (select dt from t1 where t1.po = t2.po);
     
            PO MIN_DT
    ---------- --------
             1 10/01/12
     
    SQL> MERGE INTO T1
      2  USING ( SELECT PO, MIN (DT) AS MIN_DT
      3            FROM T2
      4           GROUP BY PO
      5          having min(dt) <> (select dt from t1 where t1.po = t2.po)
      6        )  T
      7     ON (T1.PO = T.PO)
      8   WHEN MATCHED THEN UPDATE
      9    SET T1.DT =  T.MIN_DT
     10   WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
     
    1 row merged.
     
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 10/01/12
             2 30/03/12
             3 01/05/12
     
    SQL>
    Mais est ce correct niveau perf ?
    Merci je vais tester avec la clause HAVING.

  16. #16
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par skuatamad Voir le message
    En modifiant la requête du USING pour ne sélectionner que les lignes que l'on souhaite modifier c'est possible :
    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
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 15/01/12
             2 30/03/12
             3 01/05/12
     
    SQL> select * from t2;
     
            PO DT
    ---------- --------
             1 10/01/12
             1 15/01/12
             2 30/03/12
             2 14/04/12
             4 14/04/12
     
    SQL> SELECT PO, MIN (DT) AS MIN_DT
      2    FROM T2
      3   GROUP BY PO
      4  having min(dt) <> (select dt from t1 where t1.po = t2.po);
     
            PO MIN_DT
    ---------- --------
             1 10/01/12
     
    SQL> MERGE INTO T1
      2  USING ( SELECT PO, MIN (DT) AS MIN_DT
      3            FROM T2
      4           GROUP BY PO
      5          having min(dt) <> (select dt from t1 where t1.po = t2.po)
      6        )  T
      7     ON (T1.PO = T.PO)
      8   WHEN MATCHED THEN UPDATE
      9    SET T1.DT =  T.MIN_DT
     10   WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
     
    1 row merged.
     
    SQL> select * from t1;
     
            PO DT
    ---------- --------
             1 10/01/12
             2 30/03/12
             3 01/05/12
     
    SQL>
    Mais est ce correct niveau perf ?
    Testé et approuvé, les perfs sont très bonnes
    Par contre je n'ai pas le nombre de lignes mises à jour donc c'est troublant parce que je ne peux pas vérifier d'un coup d'oeil si l'update est correct. J'ai une requête de vérification mais un comptage après le merge serait pas mal comme dans ton exemple. J'utilise le logiciel PL/SQL Developer donc c'est peut être du à ça.
    merci en tout cas.

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

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Je ne connais pas PL/SQL Developer, je pense qu'il peut afficher le nombre de lignes impactées mais je ne sais pas comment.
    Un contournement serait d'utiliser un bloc PL/SQL et SQL%ROWCOUNT pour afficher le nombre de lignes merge, donc dans ton cas le nombre de lignes update :
    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
    SQL> set serverout on
    SQL> begin
    MERGE INTO T1
    USING ( SELECT PO, MIN (DT) AS MIN_DT
              FROM T2
             GROUP BY PO
            HAVING min(dt) <> (SELECT dt FROM t1 WHERE t1.po = t2.po)
          )  T
       ON (T1.PO = T.PO)
     WHEN MATCHED THEN UPDATE
      SET T1.DT =  T.MIN_DT
     WHEN NOT MATCHED THEN INSERT (PO) VALUES (NULL);
    dbms_output.put_line('nb lignes merge = '||to_char(SQL%ROWCOUNT));
    end;
    /
    nb lignes merge = 1
     
    PL/SQL procedure successfully completed.
     
    SQL>

  18. #18
    Futur Membre du Club
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Octobre 2011
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Octobre 2011
    Messages : 21
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par skuatamad Voir le message
    Je ne connais pas PL/SQL Developer, je pense qu'il peut afficher le nombre de lignes impactées mais je ne sais pas comment.
    Un contournement serait d'utiliser un bloc PL/SQL et SQL%ROWCOUNT pour afficher le nombre de lignes merge, donc dans ton cas le nombre de lignes update :
    Merci de ton aide !

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

Discussions similaires

  1. Update avec min ?
    Par sdisp+ dans le forum MS SQL Server
    Réponses: 14
    Dernier message: 11/03/2012, 16h37
  2. UPDATE avec des variables Delphi ...
    Par Kokito dans le forum Bases de données
    Réponses: 3
    Dernier message: 08/03/2004, 22h35
  3. Requete d'update avec concatenation !!
    Par chris92 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 25/02/2004, 12h05
  4. [version] Requete Update avec différentes versions de mySQL
    Par regbegpower dans le forum Requêtes
    Réponses: 2
    Dernier message: 26/01/2004, 17h19
  5. Pb Update avec chaine de caractere
    Par JuJu° dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/05/2003, 15h58

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