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

ASP.NET Discussion :

Suppression double dans une Grid


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Par défaut Suppression double dans une Grid
    Bonjour,

    Je rencontre un petit problème lors de la suppression dans une grid: Quand je supprime un enregistrement, (que j'ajoute le 2eme Delete ou non) il est bien supprimé dans la table Conseil_Prudence mais pas dans la table Article_Conseil.
    Or, bien entendu lorsqu'on supprime un conseil de prudence, la table de liaison qui contient l'id du produit et le code conseil ne doit plus contenir d'enregistrement contenant ce code conseil.

    voici mon datasource:

    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
    <asp:SqlDataSource ID="SqlDataSourceConseil" runat="server" ConnectionString="<%$ ConnectionStrings:prodchimiquesConnectionString %>"
                SelectCommand="SELECT Code_Conseil, Libelle_Conseil FROM Conseil_Prudence ORDER BY Code_Conseil"
                DeleteCommand="DELETE FROM Conseil_Prudence WHERE Code_Conseil = @original_Code_Conseil; DELETE FROM Article_Conseil WHERE Code_Conseil = @original_Code_Conseil;" 
                InsertCommand="INSERT INTO Conseil_Prudence(Code_Conseil, Libelle_Conseil) VALUES (@Code_Conseil, @Libelle_Conseil)"
                UpdateCommand="UPDATE Conseil_Prudence SET Code_Conseil = @Code_Conseil, Libelle_Conseil = @Libelle_Conseil WHERE Code_Conseil = @original_Code_Conseil AND Libelle_Conseil = @original_Libelle_Conseil"
                OldValuesParameterFormatString="original_{0}"
                ConflictDetection="CompareAllValues">
                <DeleteParameters>
                    <asp:Parameter Name="@original_Code_Conseil" Type="String"/>
                </DeleteParameters>
                <UpdateParameters>
                    <asp:Parameter Name="@Code_Conseil" Type="String"/>
                    <asp:Parameter Name="@Libelle_Conseil" Type="String"/>
                    <asp:Parameter Name="@original_Code_Conseil" Type="String"/>
                    <asp:Parameter Name="@original_Libelle_Conseil" Type="String"/>
                </UpdateParameters>
                <InsertParameters>
                    <asp:Parameter Name="@Code_Conseil" Type="String" />
                    <asp:Parameter Name="@Libelle_Conseil" Type="String" />
                </InsertParameters>
            </asp:SqlDataSource>

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Septembre 2009
    Messages
    220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 220
    Par défaut
    En attendant je me suis débrouillé avec l'evenement ItemCommand de ma grid pour supprimer dans la 2eme table, mais c'est franchement pourri d'avoir une supression effectuée à l'aide du SqlDataSource et l'autre en code behind
    Donc je laisse ouvert si quelqu'un a une idée

  3. #3
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Salut,

    A ta place, je laisserais le SGBD faire son travail . Si tu définit une suppression en 'Cascade' pour ton foreign key, ça te fera l'affaire.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE TABLE Article_Conseil
    (CLE INT,
    [Code_Conseil] int,
    FOREIGN KEY ([Code_Conseil]) REFERENCES Conseil_Prudence
    ON DELETE CASCADE)
    Maintenant si tu supprime une ligne du conseil_Prudence, tout enregistrement qui fait référence à ce ligne sera supprimé à leur tour.

    a+

Discussions similaires

  1. suppression caratère " dans une chaîne
    Par sandra771 dans le forum C
    Réponses: 10
    Dernier message: 16/11/2006, 14h57
  2. [web] Wxperl -> ajout de ligne dans une grid
    Par Airmoi dans le forum Interfaces Graphiques
    Réponses: 1
    Dernier message: 08/11/2006, 15h55
  3. Suppression enregistrement dans une table
    Par elkhy dans le forum Access
    Réponses: 3
    Dernier message: 25/04/2006, 14h29
  4. [C/C++] afficher des doubles dans une message box
    Par lalaurie40 dans le forum MFC
    Réponses: 1
    Dernier message: 24/05/2005, 14h55
  5. Réponses: 3
    Dernier message: 12/06/2002, 21h15

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