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 :

[SQLServer 2008 R2] Problème de blocage - code erreur 1222


Sujet :

Développement SQL Server

  1. #1
    Expert éminent sénior
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 413
    Points : 19 609
    Points
    19 609
    Par défaut [SQLServer 2008 R2] Problème de blocage - code erreur 1222
    * Bonjour, *

    Lors de l'exécution d'une requête SELECT je prends une erreur 1222 ayant pour description "Délai de requête de verrou dépassé.".

    Une transaction a échoué précédemment.
    Pourtant, la table impliquée dans le SELECT ne fait pas parti de la transaction !

    La requête suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM sys.dm_tran_locks WHERE request_owner_type = 'TRANSACTION'
    Renvoi plusieurs enregistrements alors que l'application ne fonctionne pas forcément.

    Comment supprimer ces blocages ?

    * Merci *
    Un problème avec Git ? Essayez la FAQ, sinon posez votre question sur le forum.



    "Toute personne croyant qu'une croissance exponentielle peut durer indéfiniment dans un monde fini est soit un fou, soit un économiste."
    Kenneth E. Boulding

    "Les richesses naturelles sont inépuisables, car, sans cela, nous ne les obtiendrions pas gratuitement. Ne pouvant être ni multipliées ni épuisées, elles ne sont pas l’objet des sciences économiques."
    Jean-Baptiste Say, Traité d'économie politique, 1803.

    "/home/earth is 102% full ... please delete anyone you can."
    Inconnu

  2. #2
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Une méthode de contournement

    1.) Obtenir la valeur actuelle du paramètre LOCK_TIMEOUT, à l'aide de la commande

    2.) augmenter le delai du timeout à l'aide de LOCK_TIMEOUT X

    (X est le nombre de millisecondes ).


    Exemple
    --------
    pour fixer le delai du timeout à 3 secondes il faut exécuter

    Etienne ZINZINDOHOUE
    Billets-Articles

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    1 056
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2007
    Messages : 1 056
    Points : 1 216
    Points
    1 216
    Par défaut
    salut

    @Etienne :

    Utilisation du lock_timeout : c'est un peu la méthode de l'autruche ;-) Ma requête est bloquée, ce n'est pas normal mais ce n'est pas grave car elle renvoie une erreur 1222 au bout de N secondes. Donc ces erreurs apparaîtront toujours.

    Et c'est bien le soucis dans ce cas : une application .NET a par un timeout défaut qu'il faut corriger dans le code (connection.CommandTimeout (30 sec par défaut) avec .NET). C'est une aberration, et je rencontre ce soucis sur un grand nombre d'applis qui n'ont pas forcément un code à toute épreuve. Donc l'appli sort une erreur 1222 car la requête a mis plus de 30 sec à s'exécuter. Il faut donc positionner ce paramètre à 0 (temps d'exécution sans limite), malgré les conseils de Microsoft de faire l'autruche ;-).

    Une erreur 1222 indique un problème grave qu'il faut résoudre.

    Quand ta requête est bloquée, utilises donc la vue sys.dm_exec_requests pour afficher la liste des requêtes en cours d'exécution et repère celles pour lesquelles le blocking_session_id > 0.

    Le numéro de ce champs indique le numéro de session de la session qui bloque.

    Ensuite tu peux essayer d'afficher le code SQL de cette requête avec
    DBCC INPUTBUFFER(<blocking_session_id>) ou utiliser une commande pour afficher l'utilisation des verrous (sp_lock par ex).

    Il faudrait alors poster les commandes qui s'entrebloquent.
    Emmanuel T.

  4. #4
    Membre émérite

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Points : 2 856
    Points
    2 856
    Par défaut
    Salut Emmanuel,
    Mais j'ai proposé "Une méthode de contournement" ;-) allez disons plutôt une méthode de l'autruche ;-)

    Sinon sur le fond je suis d'accord ;-)

    A+
    Etienne ZINZINDOHOUE
    Billets-Articles

  5. #5
    Expert éminent sénior
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 413
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 413
    Points : 19 609
    Points
    19 609
    Par défaut
    La première proposition de solution est inappropriée car comme vous le dites vous mêmes, elle ne fait que masquer le problème.

    L'exécution de cette requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM sys.dm_exec_requests WHERE blocking_session_id > 0
    Ne donne aucun résultat. En enlevant la condition il y a quelques résultats.

    Ceci dit, mon chef m'indique qu'il a mis en place un backup quotidien de la BDD qui s'exécute en soirée. Et ce matin je n'ai plus le problème de blocage. Disparu !

    Je continuerai ce fil lorsque le problème ce représentera après exécution de la requête ci-dessus.

    Sinon le LOCK_TIMEOUT est par défaut à -1 sur cette base.

    Merci pour votre aide.
    Un problème avec Git ? Essayez la FAQ, sinon posez votre question sur le forum.



    "Toute personne croyant qu'une croissance exponentielle peut durer indéfiniment dans un monde fini est soit un fou, soit un économiste."
    Kenneth E. Boulding

    "Les richesses naturelles sont inépuisables, car, sans cela, nous ne les obtiendrions pas gratuitement. Ne pouvant être ni multipliées ni épuisées, elles ne sont pas l’objet des sciences économiques."
    Jean-Baptiste Say, Traité d'économie politique, 1803.

    "/home/earth is 102% full ... please delete anyone you can."
    Inconnu

  6. #6
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Vous pouvez regarder ce billet et pour une vue plus générale, celui-ci

    @++

Discussions similaires

  1. Problème de mémoire (code erreur: 0403-031)
    Par bertinblb dans le forum AIX
    Réponses: 1
    Dernier message: 06/05/2013, 12h03
  2. Erreur d'exécution d'une requête liée sous sqlserver 2008
    Par zanoubya dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 25/05/2012, 13h56
  3. Réponses: 3
    Dernier message: 19/11/2010, 23h27
  4. Problème de code: Erreur 9999
    Par johannj dans le forum MATLAB
    Réponses: 4
    Dernier message: 17/12/2009, 20h04
  5. SqlServer 2008 Problème de tri
    Par MKiwi dans le forum Développement
    Réponses: 2
    Dernier message: 27/07/2009, 13h51

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