SQL Server update trigger executing twice -


मेरे पास निम्न ट्रिगर हैं -

  USE [DatabaseA] जाओ / **** ** ऑब्जेक्ट: ट्रिगर [डीबीओ]। [T_TableA_U] स्क्रिप्ट दिनांक: 02/17/2014 18:08:44 ****** / SET एएनएसआई_एनएलएलएस जाओ जाओ ट्यूटोरियल जाओ [डीबीओ] पर [सेट करें] पर [T_TableA_U]। [डीबीओ]। [टेबल ए] अद्यतन के बाद DECLARE @HistoryType char (1) पर सेट करें - "I" = डालें, "यू" = अपडेट, "डी" = DECLARE @RevisionID INT SET @HistoryType = 'U' SET @RevisionID = 0 [B] [तालिका] (स्तंभ 1_रेवटीएम, स्तंभ 2_आरवटाइप, स्तंभ 3_id, स्तंभ 4_रेविड, स्तंभ 5_प्रकार, ....) का चयन करें (), @ हिस्ट्रीटाइप, a.column1_id, @RevisionID, एक .column2, .... से तालिका ए में एक भीतरी सम्मिलित किया गया i.column1_id = i.column1_id  

पर अगर मैं मैन्युअल रूप से स्रोत में एक पंक्ति अपडेट करता हूं तो DESTINATION में 1 नई पंक्ति बनाता है । यह अच्छा है।

जब मैं तीसरे पक्ष के अनुप्रयोग का उपयोग करता हूं तब भी मैं इस ट्रिगर का निर्माण कर रहा हूं, यह DESTINATION में डुप्लिकेट पंक्तियाँ पैदा कर रहा है। सभी डेटा बिल्कुल वही है जो GETDATE () के अलावा होता है जो मुझे बताता है कि यह किसी नतीजे का अनुकरण कर रहा है जो कि अनुप्रयोग को मजबूर कर रहा है।

तो मैं इसे कैसे प्राप्त करूं? INSERT या तो इस ट्रिगर में होने से पहले किसी अंतर को नियंत्रित करने का एक तरीका है या क्या मैं DESTINATION तालिका पर एक और ट्रिगर बना सकता हूं जो कहता है कि पंक्ति एक डुप्लिकेट है, तो उनमें से केवल INSERT 1?

< P>

मुझे इस समस्या को विरासत एप्लिकेशन को डिज़ाइन किया गया है। जिस टेबल पर मैंने ट्रिगर किया था, उस पर एक पीके / एफके मिलान दूसरे टेबल से मिला था। मैंने एफके के साथ तालिका को चलाने के लिए ट्रिगर को उलट दिया और यह कोई डुप्लिकेट के साथ 1 से 1 आधार पर काम करता है, ऐसा लगता है कि विरासत एप्लिकेशन दोनों तालिकाओं को अद्यतन करता है, भले ही केवल 1 तालिका अपडेट हो।


Comments

Popular posts from this blog

c# - Reactive Extensions ControlScheduler -

scala - Play Framework - how to bind form to a session field -

c++ - Why does Visual Studio Release build break on non-executing code line -