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

SQL Anywhere Sybase Discussion :

Move d'enregistrement d'une table vers une autre


Sujet :

SQL Anywhere Sybase

  1. #1
    Membre habitué
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2008
    Messages
    97
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2008
    Messages : 97
    Points : 143
    Points
    143
    Par défaut Move d'enregistrement d'une table vers une autre
    Bonjour à tous,

    Quel est le meilleur moyen de déplacer des records d'une table vers une autre table (de même structure à une colonne près).

    Actuellement, je fais ces deux requêtes à la suite:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO TRT_Machin(Colonne1, Colonne2, Colonne3) SELECT Colonne1, Colonne2, Colonne3 FROM Machin;

    Le problème est que je dois utiliser un niveau d'isolation à Serializable, car la table est remplie/mise à jour par plein de processus et si un insert se produit entre la requête de copie et la requête de suppression, je le perds.

    A cause de ce niveau d'isolation, j'ai de temps en temps un deadlock dans sybase qui est très problématique.

    N'y a-t-il pas un autre moyen de faire le "move" qui éviterait les deadlock?

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 37
    Points : 48
    Points
    48
    Par défaut
    Citation Envoyé par mkl238 Voir le message
    N'y a-t-il pas un autre moyen de faire le "move" qui éviterait les deadlock?
    A ma connaissance, non.

    la question serait de savoir si les données de la table Machin sont identifiable uniquement (avec un clé unique) d'une part et si le contenu de la table TRT_Machin ne correspond qu'aux enregistrements nouvellement créés.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    BEGIN TRANSACTION ;
    INSERT INTO TRT_Machin(ColonneCle1, Colonne2, Colonne3) SELECT ColonneCle1, Colonne2, Colonne3 FROM Machin ;
    DELETE FROM Machin WHERE ColonneCle1 in (SELECT ColonneCle1 FROM TRT_Machin) ;
    COMMIT ;
    Sinon, probablement que l'utilisation de cursor serait plus approprié.


    DBRep

Discussions similaires

  1. copier une table d'une BDD dans une table d'une autre BDD
    Par faniette dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/05/2013, 10h17
  2. [VB.Net] Comment copier une DataRow d'une table vers une autre ?
    Par YLF dans le forum Accès aux données
    Réponses: 7
    Dernier message: 05/09/2012, 23h23
  3. Réponses: 1
    Dernier message: 19/10/2011, 12h13
  4. Copier les enregistrements d'une table vers une table d'une autre DB
    Par karinette21 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 18/11/2008, 21h50
  5. [VB.NET] Copie d'une table d'une DB vers une autre
    Par SergeF dans le forum Windows Forms
    Réponses: 9
    Dernier message: 20/11/2004, 09h54

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