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

Réseau/Web Python Discussion :

Update table SQLserver trop lent


Sujet :

Réseau/Web Python

  1. #1
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 5
    Points : 5
    Points
    5
    Par défaut Update table SQLserver trop lent
    Bonjour,

    J'aurai une question à vous poser, j'utilise pymmsql pour ma connexion au serveur mssql. je suis ameneé à faire des integration de données tous les soirs sur plusieurs bases donc le temps d'execution est tres important.
    Aujourd'hui et apres plusieurs tentatives d'optimisation je n'arrive plus a avancer.
    mon update prend 74.9s pour la mise à jour de 4587 rows. c'est exretement long d'autant plus que cette table n'a pas beaucoup d'index...etc
    ce temps je l'obtiens avec une execution ligne par ligne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    df.apply(lambda lrow: ExecuterRequete(lrow, Table,BDD,df.columns,UserCon,""), axis=1)
    Comme c'est du mssql j'ai 2 statements un pour l'insert et l'autre pour l'update apres une requete de selection.

    ps : le print juste de la requete et valeurs sans execute prend 12.73s
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    RequeteInsertion=''.join(["INSERT INTO [" , BDD , "].[dbo].[" ,Table , "] ( ",Columns," ) Values (",ValuesI,")"])
    j'utilise les parametres %s.

    Avez vous des idees?

    merci.

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Citation Envoyé par deve Voir le message
    Avez vous des idees?
    Dans la documentation de votre driver, vous devez avoir la possibilité d'un "bulk insert" via un .executemany.
    En gros, vous passez au driver la liste des "insert" plutôt que d'appeler "insert" pour chaque élément de la liste. Reste à voir si le driver sait faire un "bulk insert" vers le SGDB, ou s'il se contente de faire une "boucle" à votre place.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Futur Membre du Club
    Inscrit en
    Septembre 2005
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Septembre 2005
    Messages : 5
    Points : 5
    Points
    5
    Par défaut
    Bonjour,

    merci de votre retour, j'ai testé executemany avec pymssql mais ca ne marche pas ( il le considere comme un insert je pense et non pas un update car j'ai un message d'erreur de violation de clé).
    Hier soir j'ai changé mon driver, je suis passée à PYODBC et ça n'a rien à avoir. le temps d’exécution est divisé par au moins 2.5.

    Je voulais aller plus loin encore avec executemany mais je ne sais pas comment faire un catch d'exception pour chaque row, car il me faudrait la raison de non import (insert ou update) de chaque ligne.

    Merci.

Discussions similaires

  1. [AC-2007] Requête IN entre 2 tables trop lente
    Par Junior_jef dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 23/10/2009, 09h36
  2. pb requete trop lente.(tables sans relation)
    Par zeloutre dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 27/04/2007, 08h48
  3. Envoi de mail trop lent
    Par MASSAKA dans le forum ASP
    Réponses: 3
    Dernier message: 15/10/2004, 10h57
  4. [SQL SERVER] Table contient trop d'enregistrements ?
    Par Tankian dans le forum MS SQL Server
    Réponses: 10
    Dernier message: 10/08/2004, 10h40
  5. UPDATE : table à partir d'une autre
    Par Laura dans le forum Requêtes
    Réponses: 2
    Dernier message: 28/10/2003, 21h34

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