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

MySQL Discussion :

Enrichissement des champs null


Sujet :

MySQL

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Avril 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Enrichissement des champs null
    Bonjour à tous,

    dans ma table actuelle, j'ai ceci:
    Nom : 1.JPG
Affichages : 80
Taille : 14,0 Ko

    j'aimerais avoir ceci:

    Nom : 2.JPG
Affichages : 80
Taille : 14,4 Ko

    En gros, lorsque le sessionid est identique enrichir les null par l'id connu à un des lignes.

    quelqu'un pourrait m'aider à faire la requête qui me permettrait de faire ceci?

    d'avance un grand merci.

  2. #2
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 240
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 240
    Points : 8 514
    Points
    8 514
    Billets dans le blog
    17
    Par défaut
    Avec une sous-requête corrélée tu peux faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    UPDATE ta_table AS t1
    SET t1.id = (
        SELECT ALL *
        FROM (
            SELECT ALL t2.id
            FROM ta_table AS t2
            WHERE TRUE
                AND t2.sessionid = t1.sessionid
                AND t2.id IS NOT NULL
            LIMIT 1 -- On garde la 1re valeur non NULL qui nous tombe sous la main
        ) AS _
    )
    WHERE t1.id IS NULL
    Une 2e sous-requête pour éviter des messages d'erreur comme "You can't specify target table 't1' for update in FROM clause".

  3. #3
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 480
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 480
    Points : 19 491
    Points
    19 491
    Par défaut
    Salut à tous.

    Que ce passe-t-il si tu as deux valeurs distinctes ?
    Dans ce cas, il ne faut pas mettre à jour la colonne car tu ignores la valeur qu'il faut prendre.
    Code mysql : 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
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE IF NOT EXISTS `base`
            DEFAULT CHARACTER SET `latin1`
            DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `test`
    --------------
     
    --------------
    CREATE TABLE `test`
    ( `id`         integer unsigned NOT NULL auto_increment primary key,
      `name`       varchar(255)     NOT NULL,
      `sessionId`  varchar(255)     NOT NULL,
      `ident`      integer unsigned     NULL DEFAULT NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    INSERT INTO `test` (`name`,`sessionId`,`ident`) values
      ('test1',12,default),('test2',12,default),('test3',12,350),
      ('test4',25,default),('test5',25,33),('test6',25,default),('test7',25,49),
      ('test8',33,default),('test9',33,26),('testa',33,default),('testb',33,26)
    --------------
     
    --------------
    select * from `test`
    --------------
     
    +----+-------+-----------+-------+
    | id | name  | sessionId | ident |
    +----+-------+-----------+-------+
    |  1 | test1 | 12        |  NULL |
    |  2 | test2 | 12        |  NULL |
    |  3 | test3 | 12        |   350 |
    |  4 | test4 | 25        |  NULL |
    |  5 | test5 | 25        |    33 |
    |  6 | test6 | 25        |  NULL |
    |  7 | test7 | 25        |    49 |
    |  8 | test8 | 33        |  NULL |
    |  9 | test9 | 33        |    26 |
    | 10 | testa | 33        |  NULL |
    | 11 | testb | 33        |    26 |
    +----+-------+-----------+-------+
    --------------
    update     `test` as t1
    inner join (   select `sessionId`,any_value(`ident`) as ident
                     from `test`
                    where `ident` is not null
                 group by `sessionId`
                   having count(distinct `ident`) < 2
               ) as t2
            on t2.`sessionId` = t1.`sessionId`
           set t1.`ident` = t2.`ident`
    --------------
     
    --------------
    select * from `test`
    --------------
     
    +----+-------+-----------+-------+
    | id | name  | sessionId | ident |
    +----+-------+-----------+-------+
    |  1 | test1 | 12        |   350 |
    |  2 | test2 | 12        |   350 |
    |  3 | test3 | 12        |   350 |
    |  4 | test4 | 25        |  NULL |
    |  5 | test5 | 25        |    33 |
    |  6 | test6 | 25        |  NULL |
    |  7 | test7 | 25        |    49 |
    |  8 | test8 | 33        |    26 |
    |  9 | test9 | 33        |    26 |
    | 10 | testa | 33        |    26 |
    | 11 | testb | 33        |    26 |
    +----+-------+-----------+-------+
    --------------
    COMMIT
    --------------
     
    Appuyez sur une touche pour continuer...

    Cordialement.
    Artemus24.
    @+

  4. #4
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Avril 2013
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2013
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par Séb. Voir le message
    Avec une sous-requête corrélée tu peux faire ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    UPDATE ta_table AS t1
    SET t1.id = (
        SELECT ALL *
        FROM (
            SELECT ALL t2.id
            FROM ta_table AS t2
            WHERE TRUE
                AND t2.sessionid = t1.sessionid
                AND t2.id IS NOT NULL
            LIMIT 1 -- On garde la 1re valeur non NULL qui nous tombe sous la main
        ) AS _
    )
    WHERE t1.id IS NULL
    Une 2e sous-requête pour éviter des messages d'erreur comme "You can't specify target table 't1' for update in FROM clause".

    Top, merci!

Discussions similaires

  1. permettre de mettre a jour des champs null
    Par alexkickstand dans le forum VBA Access
    Réponses: 1
    Dernier message: 23/08/2007, 19h37
  2. Réponses: 14
    Dernier message: 23/07/2007, 17h29
  3. Requete avec des champs null
    Par passie dans le forum Langage SQL
    Réponses: 3
    Dernier message: 15/06/2006, 15h11
  4. Réponses: 3
    Dernier message: 28/02/2006, 17h52
  5. somme des champs null
    Par s.rais dans le forum Access
    Réponses: 4
    Dernier message: 09/02/2006, 09h05

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