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

PHP & Base de données Discussion :

Amélioration performance requête [Fait] [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut Amélioration performance requête
    Bonjour,

    J'ai une requête mysql qui fonctionne très bien.

    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
    $req = "SELECT maj_etat_civil.id_maj,id_user,maj_num_dos,maj_civilite_id, CONCAT(maj_nom,' ', maj_prenom,' ', maj_prenom_usage) as maj_nom,maj_etat_civil.id_trt,
    			CONCAT(tiers_nom,' ',tiers_adr1,' ',tiers_adr2,' ',tiers_adr3,' ',cp,' ',libelle) as maj_prenom
    			FROM ".$prefixe_table."t_users_dossiers
    			LEFT OUTER JOIN ".$prefixe_table."maj_etat_civil 
    			ON t_users_dossiers.id_maj=maj_etat_civil.id_maj
    			LEFT OUTER JOIN ".$prefixe_table."maj_adresses
    			ON t_users_dossiers.id_maj=maj_adresses.id_maj
    			LEFT OUTER JOIN ".$prefixe_table."t_tiers
    			ON t_tiers.id_tiers=maj_adresses.id_tiers
    			LEFT OUTER JOIN ".$prefixe_table."t_ville
    			ON t_ville.ville_id=t_tiers.tiers_ville_id
    			WHERE '".$today."' BETWEEN (gest_date_debut AND gest_date_fin)
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_nom LIKE '%$argument2%'
    			OR '".$today."'>=gest_date_debut 
    			AND 0<=gest_date_fin
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_nom LIKE '%$argument2%'
    			OR '".$today."' BETWEEN (gest_date_debut AND gest_date_fin)
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr1 LIKE '%$argument2%'
    			OR '".$today."'>=gest_date_debut 
    			AND 0<=gest_date_fin
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr1 LIKE '%$argument2%'
    			OR '".$today."' BETWEEN (gest_date_debut AND gest_date_fin)
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr2 LIKE '%$argument2%'
    			OR '".$today."'>=gest_date_debut 
    			AND 0<=gest_date_fin
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr2 LIKE '%$argument2%'
    			'".$today."' BETWEEN (gest_date_debut AND gest_date_fin)
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr3 LIKE '%$argument2%'
    			OR '".$today."'>=gest_date_debut 
    			AND 0<=gest_date_fin
    			AND t_users_dossiers.id_trt 
    			BETWEEN 1 AND 4
    			AND maj_etat_civil.id_trt 
    			BETWEEN 1 AND 4
    			AND tiers_adr3 LIKE '%$argument2%'
    			ORDER BY maj_nom, maj_prenom
    			limit $start,$nb_majeur";
    Mon problème est juste au niveau de la performance. Existe-t-il une syntaxe plus légère de requête pour mysql au niveau de mes "OR" ?

    Merci d'avance

  2. #2
    Rédactrice
    Avatar de xave
    Femme Profil pro
    Développeur Web
    Inscrit en
    Mai 2002
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2002
    Messages : 871
    Par défaut
    Salut,

    Là franchement je ne sais pas mais va jeter un oeil , c'est pas forcément du MySQL mais il y a de bons conseils pour optimiser les requêtes.

  3. #3
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    Merci Xave, après relecture de ces tutos, je ne vois rien.

    Je pensais plus à la syntaxe de ma requête.

  4. #4
    Rédactrice
    Avatar de xave
    Femme Profil pro
    Développeur Web
    Inscrit en
    Mai 2002
    Messages
    871
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2002
    Messages : 871
    Par défaut
    Concernant la syntaxe, je ne vois pas ce que tu pourrais modifier...

    Essaie peut-être d'aller poser ta question dans le forum Base de données, c'est plus spécifiquement du SQL que du php, tu y trouveras certainement une meilleure réponse.

    Au besoin je peux déplacer ton message.

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 43
    Par défaut
    D'après mon gros livre de PHP une requete préparé avec la fonction mysqli_prepare() puis exécuté avec les fonctions qui vont avec serait plus rapide qu'une fonction préparé puis exécuté par mysqli_query().

    je sais pas trop si c'est vrais mais bon tu peux toujours tanté, mais fonctionne que depuis php 5

  6. #6
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    Merci, mais le serveur n'est pas encore prêt pour le PHP5.

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

Discussions similaires

  1. Performance requête vb
    Par mariemor64 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 07/06/2007, 12h24
  2. access amélioration performance ouverture
    Par estebandelago dans le forum Access
    Réponses: 2
    Dernier message: 05/03/2007, 14h48
  3. améliorer une requête
    Par papilou86 dans le forum Access
    Réponses: 5
    Dernier message: 22/05/2006, 11h40
  4. [Performances]Requête de sommation
    Par m-mas dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 09/11/2005, 11h38
  5. [Access] Optimisation performance requête - Index
    Par fdraven dans le forum Access
    Réponses: 11
    Dernier message: 12/08/2005, 14h30

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