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

Développement SQL Server Discussion :

Délai d'exécution de requête trop long


Sujet :

Développement SQL Server

  1. #1
    Invité
    Invité(e)
    Par défaut Délai d'exécution de requête trop long
    Bonjour, en fait je travaille sur un programme, j'ai un service windows qui me fait remplir une base de donnée durant toute la journée, il envoie environ 1500 variable par seconde du coup la base de donnée se grande après quelques heures, en paralléle j'ai un Gui pour filtrer les données stocké en fonction de leur type et la date

    mon problème c'est le temps d’exécutions des requête qui devient de plus en plus long avec le temps, alors que quand la base de donnée est pas trop chargé il l’exécute en moins de temps, chose qui me fait beuger le programme

    exemple d'une requête exécuté sur sql server management studio

    la structure de mon tableau


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Create table DatafromDGV
    (
    ID int,
    Status nvarchar(100),
    Tag nvarchar(100),
    [Date] datetime,
    Class_name nvarchar(100)
    )
    Go

    ça a pris plus que 5 min pour l'exécuter sachant que j'utilise les 3 colonne Classe_name, Date, et Tag de temps en temps pour la requéte

    Nom : Capture.PNG
Affichages : 1164
Taille : 111,0 Ko
    Dernière modification par al1_24 ; 12/02/2020 à 15h53. Motif: Balises CODE

  2. #2
    Invité
    Invité(e)
    Par défaut
    Quelles sont les clef primaire et indexes de la table ?

  3. #3
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par 7gyY9w1ZY6ySRgPeaefZ Voir le message
    Quelles sont les clef primaire et indexes de la table ?
    j'ai pas utilisé les clef primaire et les indexes , ils sont indispensable pour le traitement des grande base de données ?

    J'ai modifier le tableau que j'utilise dans la requete en mettant id comme clef primaire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Create table DatafromDGV
    (
    [id] [int] NOT NULL IDENTITY PRIMARY KEY,
    Status nvarchar(100),
    Tag nvarchar(100),
    [Date] datetime,
    Class_name nvarchar(100)
    )
    Go
    ça m a pas trop aidé
    Dernière modification par al1_24 ; 12/02/2020 à 15h54. Motif: Balises CODE

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par magmaaka Voir le message
    j'ai pas utilisé les clef primaire et les indexes , ils sont indispensable pour le traitement des grande base de données ?

    lol ! OUI INDISPENSABLE !!!

  5. #5
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 636
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    D'après le script communiqué, il y a bien une PK mais a priori pas d'index sur les colonnes de filtrage, du coup il faut parcourir séquentiellement toute la table pour vérifier si les dates sont dans la période recherchée et si la classe correspond aux valeurs souhaitées.

    quelques remarques par ailleurs
    - select * est dangereux et contre-performant
    - nommer une colonne avec un nom réservé SQL comme "date" est un mauvais choix qui rend les requêtes inutilement complexes, à corriger si possible
    - faire un filtre like '%%' ne présente aucun intérêt
    - filtrer des dates au format 'JJ/MM/AAAA' provoque une conversion de type qui nuit aux performances, à remplacer par 'AAAA-MM-JJ'
    - avec 1500 lignes par secondes, la table va rapidement devenir énorme, un index sur la colonne timestamp est donc indispensable, il faudra également réfléchir au partitionnement et à la durée de rétention
    - quelles sont les valeurs possibles pour class_name ? Dans l'exemple on voit 'UPS' et 'HS' soit 2 à 3 caractères, si toutes les autres valeurs sont ce genre de codes très courts, remplacez avantageusement votre nvarchar(100) par du char(3) ou un peu plus selon le besoin
    - même remarque concernant la colonne status

  6. #6
    Membre émérite

    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Novembre 2014
    Messages
    817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Auditeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2014
    Messages : 817
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    Bonjour,
    filtrer des dates au format 'JJ/MM/AAAA' provoque une conversion de type qui nuit aux performances, à remplacer par 'AAAA-MM-JJ'
    le colonne date est définit en datetime (type obsolete) et non pas datetime2 donc c'est 'AAAAMMJJ' et non pas AAAA-MM-JJ

  7. #7
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    En plus de ce qui a été dit :
    1) le type DATETIME2 est plus rapide
    2) avez-vous dimensionné vos espaces de stockage de données et de transaction de manière suffisante ?

    Pour cette dernière question je vous invite à lancer la requête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT name, DatabaseName, FileName, StartTime, EndTime, Duration,
           SUM(Duration) OVER() AS TOTAL_Duration
    FROM   sys.traces
           CROSS APPLY sys.fn_trace_gettable(path, DEFAULT) TRC
           JOIN sys.trace_events AS te
                ON TRC.EventClass = te.trace_event_id
    WHERE  te.name LIKE '%Auto Grow'
       OR  te.name LIKE '%Auto Shrink'
    Cela vous montrera si vous passez plus de temps à bricoler les fichiers de la base au niveau système, plutôt qu'à faire du relationnel.
    Et par conséquent, si tel est le cas, dimensionnez vos fichiers pour un service de données de plusieurs années.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  8. #8
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    Je rajouterai...

    Avez-vous réellement besoin de NVARCHARIl y a de fortes chances pour que le VARCHAR soit suffisant, voire le CHAR

  9. #9
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 636
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 636
    Billets dans le blog
    10
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    Je rajouterai...

    Avez-vous réellement besoin de NVARCHARIl y a de fortes chances pour que le VARCHAR soit suffisant, voire le CHAR
    Déjà cité

    Citation Envoyé par escartefigue Voir le message
    - quelles sont les valeurs possibles pour class_name ? Dans l'exemple on voit 'UPS' et 'HS' soit 2 à 3 caractères, si toutes les autres valeurs sont ce genre de codes très courts, remplacez avantageusement votre nvarchar(100) par du char(3) ou un peu plus selon le besoin
    - même remarque concernant la colonne status

  10. #10
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    Bonjour,

    D'après le script communiqué, il y a bien une PK mais a priori pas d'index sur les colonnes de filtrage, du coup il faut parcourir séquentiellement toute la table pour vérifier si les dates sont dans la période recherchée et si la classe correspond aux valeurs souhaitées.

    quelques remarques par ailleurs
    - select * est dangereux et contre-performant
    - nommer une colonne avec un nom réservé SQL comme "date" est un mauvais choix qui rend les requêtes inutilement complexes, à corriger si possible
    - faire un filtre like '%%' ne présente aucun intérêt
    - filtrer des dates au format 'JJ/MM/AAAA' provoque une conversion de type qui nuit aux performances, à remplacer par 'AAAA-MM-JJ'
    - avec 1500 lignes par secondes, la table va rapidement devenir énorme, un index sur la colonne timestamp est donc indispensable, il faudra également réfléchir au partitionnement et à la durée de rétention
    - quelles sont les valeurs possibles pour class_name ? Dans l'exemple on voit 'UPS' et 'HS' soit 2 à 3 caractères, si toutes les autres valeurs sont ce genre de codes très courts, remplacez avantageusement votre nvarchar(100) par du char(3) ou un peu plus selon le besoin
    - même remarque concernant la colonne status

    --------------
    .Je vous remercie pour votre réponse bien détaillé :

    la j'ai changé un peut ce que vous m'avez dit, pour mon tableau c'est devenu :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Create table DatafromDGV2
    (
    ID [int] NOT NULL IDENTITY PRIMARY KEY,
    Status char(25),
    Tag char(25),
    [Date_entr] datetime,
    Class_name char(12),
    index Classename (Class_name),
    index Tagrecherche (Tag),
    index Datesearch (Date_entr),
    )
    Go

    le resultat de la requête ça prends encore vers les 26 secondes pour environs 100 000 lignes

    Pouvez vous m'expliquer le message index absent sachant que j'ai indexer les 3 colonnes que j'utilise pour filtrer

    Nom : Capture.PNG
Affichages : 1047
Taille : 41,8 Ko

  11. #11
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    En plus de ce qui a été dit :
    1) le type DATETIME2 est plus rapide
    2) avez-vous dimensionné vos espaces de stockage de données et de transaction de manière suffisante ?

    Pour cette dernière question je vous invite à lancer la requête suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT name, DatabaseName, FileName, StartTime, EndTime, Duration,
           SUM(Duration) OVER() AS TOTAL_Duration
    FROM   sys.traces
           CROSS APPLY sys.fn_trace_gettable(path, DEFAULT) TRC
           JOIN sys.trace_events AS te
                ON TRC.EventClass = te.trace_event_id
    WHERE  te.name LIKE '%Auto Grow'
       OR  te.name LIKE '%Auto Shrink'
    Cela vous montrera si vous passez plus de temps à bricoler les fichiers de la base au niveau système, plutôt qu'à faire du relationnel.
    Et par conséquent, si tel est le cas, dimensionnez vos fichiers pour un service de données de plusieurs années.

    A +
    Svp comment je peux analyser les résultats de la requête

    Nom : Capture.PNG
Affichages : 1628
Taille : 47,5 Ko

  12. #12
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Par défaut
    essayez cet index :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    CREATE INDEX IX_Date_Classe ON DatafromDGV2([Date], Class_name) INCLUDE(Tag, Status)

  13. #13
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    essayez cet index :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    CREATE INDEX IX_Date_Classe ON DatafromDGV2([Date], Class_name) INCLUDE(Tag, Status)
    ---------------
    C'est beaucoup plus rapide, je vous remercie

  14. #14
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 010
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 22 010
    Billets dans le blog
    6
    Par défaut
    Citation Envoyé par magmaaka Voir le message
    Svp comment je peux analyser les résultats de la requête

    Nom : Capture.PNG
Affichages : 1628
Taille : 47,5 Ko

    Il faut lancer la requête ! Pas l'analyser !!!!!

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. [Oracle] Requête trop longue à exécuter, trop de résultats
    Par diabli73 dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 03/12/2010, 11h27
  2. [MySQL] Exécution d'une requête trop longue
    Par Smip99 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 12/06/2008, 09h52
  3. [Requête] Requête trop longue
    Par Ithilien dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 08/01/2007, 10h58
  4. [MySQL] Requête trop longue ?
    Par Thomas1434 dans le forum PHP & Base de données
    Réponses: 14
    Dernier message: 24/03/2006, 21h55

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