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

MS SQL Server Discussion :

trigger instead of insert, bug très étrange (bug de sql server ?)


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut trigger instead of insert, bug très étrange (bug de sql server ?)
    bonjour

    j'ai un trigger instead of insert qui plante, j'ai réduit le code pour mettre le problème en évidence :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    ALTER TRIGGER [dbo].[GestionHistoriqueInsteadOfInsertArticleCompartiment] ON [dbo].[ArticleCompartiment] INSTEAD OF INSERT
    AS
    BEGIN
     
    SELECT TOP 1 * INTO #aInserer FROM ArticleCompartiment
    DELETE FROM #aInserer
    INSERT INTO ArticleCompartiment SELECT * FROM #aInserer
     
    END
    à l'origine je voulais créé une table temporaire dans laquelle je mets inserted
    je fais des modifs dans cette table temporaire
    en enfin je fait rentrer ce qu'il y a dans cette temporaire dans la vraie table
    (les triggers récursifs sont désactivés sur la base)

    le code restant et qui bug encore c'est la création de la table # à l'identique de la vraie table (je la vide pour que ca n'insert rien, le problème ne vient pas des données)
    puis je reverse dans la vraie table
    (j'ai dejà plusieurs triggers dans le genre, les autres fonctionnent

    et le message d'erreur est :
    Msg*213, Niveau*16, État*1
    Erreur INSERT*: le nom ou le numéro de colonne des valeurs fournies ne correspond pas à la définition de la table.


    j'ai essayé plusieurs méthodes meme en créant la table # avec un create table et en nommant les champs comme la vraie table, ca me mets un message d'erreur par colonne en disant qu'elle existe pas

    si quelqu'un peut m'aider parce que là franchement je vois pas du tout comment remédier à ca

    merci
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  2. #2
    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 : 43
    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
    Par défaut
    Bonsoir,

    Il y a quelque chose que je ne comprends pas :

    - SELECT TOP 1 * INTO #aInserer FROM ArticleCompartiment : Vous insérez une ligne de données dans une table temporaire
    - DELETE FROM #aInserer : vous les supprimez ensuite, donc votre table temporaire est vide
    - INSERT INTO ArticleCompartiment SELECT * FROM #aInserer : par conséquent vous n'insérez rien dans votre table ArticleCompartiment.

    En tout état de cause, le mieux reste d'utiliser le moins possible les tables temporaires, et encore moins dans les triggers. Rappelez-vous que le code qui est dans votre trigger fait partie, lors de l'exécution d'une insertion par une procédure stockée appelante, de la même transaction.

    Je suis persuadé que vous pouvez faire vos modifications directement depuis INSERTED. Quelles modifications voulez-vous faire ?

    A+

  3. #3
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    vous etes pas très au point on dirait

    deja j'ai expliqué que le code ici était pour ne laisser que ce qui est necessaire à comprendre le bug, je sais que j'insere rien, le vrai code n'est pas ca, mais celui ci plante aussi

    les tables temporaires c'est très utile y a plein de choses qu'on ne peut pas faire sinon (ou de manière moins propre, et parfois beaucoup moins rapide)


    et la table inserted (ou deleted) n'est pas modifiable ...
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  4. #4
    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 : 43
    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
    Par défaut
    Bonjour,

    vous etes pas très au point on dirait
    C'est fort probable. En revanche si vous l'étiez plus que moi, vous sauriez qu'il faut avoir recours le moins possible aux tables temporaires, et qu'il vaut 100 fois mieux utiliser du code ensembliste.

  5. #5
    Expert éminent Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 197
    Par défaut
    arguments ??
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  6. #6
    Membre Expert Avatar de Jinroh77
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Février 2006
    Messages
    1 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence

    Informations forums :
    Inscription : Février 2006
    Messages : 1 964
    Par défaut
    Les tables temporaire ne se retrouvent-elles pas dans la tempDB et par la même occasion sur le disque physique (non en RAM) ?

Discussions similaires

  1. Bug très étrange
    Par parazitenew dans le forum Sécurité
    Réponses: 5
    Dernier message: 01/02/2014, 01h09
  2. Création d'un trigger INSTEAD OF INSERT
    Par LestoK dans le forum Développement
    Réponses: 4
    Dernier message: 03/09/2008, 13h53
  3. [SQL2K] TRIGGER - Instead of Insert
    Par buchette dans le forum Développement
    Réponses: 3
    Dernier message: 04/06/2008, 17h33
  4. Très étrange.. Bug impression etat
    Par Invité dans le forum Access
    Réponses: 2
    Dernier message: 01/08/2006, 11h44
  5. [HTML] bug très étrange
    Par kivan666 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 21/07/2006, 12h13

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