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

Requêtes MySQL Discussion :

Dépassement de mémoire pour cause de requête trop complexe à simplifier


Sujet :

Requêtes MySQL

  1. #1
    Candidat au Club
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Juin 2014
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant en technologies
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 1
    Points : 2
    Points
    2
    Par défaut Dépassement de mémoire pour cause de requête trop complexe à simplifier
    Bonjour,

    Voici une requete pour créer une vue qui provoque cette erreur:

    Fatal error: Maximum execution time of 30 seconds exceeded in C:\htdocs\phpMyAdmin\libraries\session.inc.php on line 96
    J'aurai aimé avoir un coup de main sur son optimisation sachant que le principe est toujours le même Je fais des sous resquete pour calculer la valeur d'un champ de la table que je souhaite créer.
    Comme il y a enormement de champs à calculer, ça pète.

    Merci pour vos conseils:

    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
    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
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    CREATE ALGORITHM=UNDEFINED DEFINER=root@`appian.solypse.com` SQL SECURITY DEFINER VIEW zz_projetaffich AS 
     
    select a.id AS id,a.nom AS nom,a.comm AS comm,
    a.datecreation AS datecreation,a.idunique AS idunique,a.idrepertoire AS idrepertoire,a.versionoffre AS versionoffre,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantitegenerique)),0,sum(zz_patrimoinegenerique.quantitegenerique)) 
    from zz_patrimoinegenerique 
    where ((zz_patrimoinegenerique.idprojet = a.id) and (zz_patrimoinegenerique.codeobjet = 1) 
    and (zz_patrimoinegenerique.versionoffre = a.versionoffre))) 
    AS quantiteassociesup,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantite)),0,sum(zz_patrimoinegenerique.quantite)) 
    from zz_patrimoinegenerique 
    where ((zz_patrimoinegenerique.idprojet = a.id) and 
    (zz_patrimoinegenerique.codeobjet = 1) and (zz_patrimoinegenerique.idgenerique = '-1'))) 
    AS quantitenonassociesup,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine
    where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 1) 
    and (zz_patrimoine.codeobjet = 1))) AS 
    quantitetotvalsup,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine 
    where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 0) 
    and (zz_patrimoine.codeobjet = 1))) AS 
    quantitetotnonvalsup,
     
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantitegenerique)),0,sum(zz_patrimoinegenerique.quantitegenerique)) 
    from zz_patrimoinegenerique where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 2) 
    and (zz_patrimoinegenerique.versionoffre = a.versionoffre))) 
    AS quantiteassociecon,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantite)),0,sum(zz_patrimoinegenerique.quantite)) 
    from zz_patrimoinegenerique where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 2) 
    and (zz_patrimoinegenerique.idgenerique = '-1'))) 
    AS quantitenonassociecon,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 1) 
    and (zz_patrimoine.codeobjet = 2))) 
    AS quantitetotvalcon,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 0) 
    and (zz_patrimoine.codeobjet = 2))) 
    AS quantitetotnonvalcon,
     
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantitegenerique)),0,sum(zz_patrimoinegenerique.quantitegenerique)) 
    from zz_patrimoinegenerique
    where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 3) 
    and (zz_patrimoinegenerique.versionoffre = a.versionoffre))) 
    AS quantiteassocielum,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantite)),0,sum(zz_patrimoinegenerique.quantite)) 
    from zz_patrimoinegenerique where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 3) 
    and (zz_patrimoinegenerique.idgenerique = '-1'))) AS quantitenonassocielum,
     
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 1) 
    and (zz_patrimoine.codeobjet = 3))) 
    AS quantitetotvallum,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) and (zz_patrimoine.valide = 0) 
    and (zz_patrimoine.codeobjet = 3))) 
    AS quantitetotnonvallum,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantitegenerique)),0,sum(zz_patrimoinegenerique.quantitegenerique)) 
    from zz_patrimoinegenerique where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 4) 
    and (zz_patrimoinegenerique.versionoffre = a.versionoffre))) 
    AS quantiteassociesou,
     
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantite)),0,sum(zz_patrimoinegenerique.quantite)) 
    from zz_patrimoinegenerique 
    where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 4) 
    and (zz_patrimoinegenerique.idgenerique = '-1'))) AS 
    quantitenonassociesou,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine 
    where ((zz_patrimoine.idprojet = a.id) and (zz_patrimoine.valide = 1) 
    and (zz_patrimoine.codeobjet = 4))) AS quantitetotvalsou,
     
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) and (zz_patrimoine.valide = 0) 
    and (zz_patrimoine.codeobjet = 4))) 
    AS quantitetotnonvalsou,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantitegenerique)),0,sum(zz_patrimoinegenerique.quantitegenerique)) 
    from zz_patrimoinegenerique 
    where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 5) 
    and (zz_patrimoinegenerique.versionoffre = a.versionoffre))) 
    AS quantiteassocieapp,
     
    (select if(isnull(sum(zz_patrimoinegenerique.quantite)),0,sum(zz_patrimoinegenerique.quantite)) 
    from zz_patrimoinegenerique 
    where ((zz_patrimoinegenerique.idprojet = a.id) 
    and (zz_patrimoinegenerique.codeobjet = 5) 
    and (zz_patrimoinegenerique.idgenerique = '-1'))) 
    AS quantitenonassocieapp,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 1) 
    and (zz_patrimoine.codeobjet = 5))) 
    AS quantitetotvalapp,
     
    (select if(isnull(sum(zz_patrimoine.quantite)),0,sum(zz_patrimoine.quantite)) 
    from zz_patrimoine where ((zz_patrimoine.idprojet = a.id) 
    and (zz_patrimoine.valide = 0) 
    and (zz_patrimoine.codeobjet = 5))) 
    AS quantitetotnonvalapp 
     
    from projet a;

  2. #2
    Membre éprouvé
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2009
    Messages
    736
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2009
    Messages : 736
    Points : 1 101
    Points
    1 101
    Par défaut
    Ça fait peur ta requête.
    Sépare les sous requête en requête et fais plusieurs appeles
    A la recherche d'un film : http://chercher-un-film.com

  3. #3
    Membre averti
    Profil pro
    Administrateur
    Inscrit en
    Mai 2008
    Messages
    237
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Administrateur
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2008
    Messages : 237
    Points : 433
    Points
    433
    Par défaut Cette requête est anormalement longue
    Il me semble qu'elle peut se résumer en 3 requêtes, c'est juste une piste de reflexion

    (1)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT a.id, SUM(r.quantitegenerique) somme
    FROM projet a
    INNER JOIN zz_patrimoinegenerique r
    WHERE r.idprojet = a.id AND r.versionoffre = a.versionoffre
    GROUP BY r.codeobjet
    (2)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT a.id, SUM(r.quantite) somme
    FROM projet a
    INNER JOIN zz_patrimoine r
    WHERE r.idprojet = a.id AND r.versionoffre = a.versionoffre
    GROUP BY r.codeobjet, r.valide

    (3)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT a.id, SUM(r.quantite) somme
    FROM projet a
    INNER JOIN zz_patrimoinegenerique r
    WHERE r.idprojet = a.id AND r.idgenerique = -1
    GROUP BY r.codeobjet, r.valide

Discussions similaires

  1. Requête trop complexe pour moi
    Par dauhik dans le forum Requêtes
    Réponses: 10
    Dernier message: 12/11/2012, 13h57
  2. Requête trop complexe pour moi
    Par snips67 dans le forum Requêtes
    Réponses: 6
    Dernier message: 27/01/2010, 09h24
  3. Une requête trop complexe pour moi
    Par prgasp77 dans le forum Langage SQL
    Réponses: 13
    Dernier message: 14/01/2009, 17h12
  4. Dépassement de mémoire pour liste liées
    Par jpascal dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 03/04/2008, 21h37
  5. Simplication d'une requête "trop complexe"
    Par Manopower dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 27/06/2006, 14h22

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