आपको एक दो प्रश्न पूछने की जरूरत है।
क्या आप डीबी स्तर पर अपने किसी भी व्यावसायिक तर्क को नहीं चाहते हैं? स्पष्ट रूप से एक डीबी ट्रिगर ऐसा कर सकता है (जब कोई मूल्य बदल जाता है तो कुछ क्रिया करें, भले ही केवल विशिष्ट मूल्य ही हो)।
मैंने कुछ सिस्टम देखे हैं जो डीबी ट्रिगर भारी हैं। उनका 'तर्क' डीबी प्लेटफॉर्म के साथ गहराई से और अत्यधिक युग्मित है। इसके कुछ फायदे हैं, लेकिन ज्यादातर लोग शायद कहेंगे कि नुकसान बहुत अधिक हैं (युग्मन, encapuslation/पुन:प्रयोज्य की कमी)।
आप जो कर रहे हैं और आपके झुकाव के आधार पर आप यह कर सकते हैं:
-
सुनिश्चित करें कि सभी DAO/BusinessFunctoin ऑब्जेक्ट आपके 'ईवेंट' को कॉल करते हैं
object.functionएक निश्चित मूल्य परिवर्तन होने पर आप जो चाहते हैं उसे करने के लिए। -
अपने 'ईवेंट' को कॉल करने के लिए ट्रिगर का उपयोग करें
object.functionजब एक निश्चित मूल्य परिवर्तन होता है। -
आपका ट्रिगर सब कुछ करता है।
मैं व्यक्तिगत रूप से विकल्प 2 की ओर झुकता हूं जहां आपके पास न्यूनतम ट्रिगर होता है (जो आपके object.function पर ईवेंट कॉल को आसानी से सक्रिय करता है। ) इसलिए आप अपने डीबी को अपने व्यावसायिक तर्क से गहराई से नहीं जोड़ते हैं।
विकल्प 1 ठीक है, लेकिन थोड़ी परेशानी हो सकती है जब तक कि आपके पास बीएफ/डीएओ का एक बहुत ही संकीर्ण सेट न हो जो इस डीबी टेबल से बात करें। फ़ील्ड जिसे आप देखना चाहते हैं।
विकल्प 3 सबसे खराब विकल्प है क्योंकि आप अपने डीबी में तर्क जोड़ते हैं और अपनी व्यावसायिक तर्क परत तक इसकी पहुंच कम करते हैं।
इसे देखते हुए, विकल्प 2 के माध्यम से इसे पूरा करने के लिए यहां कुछ जानकारी दी गई है:
MSDN से इस उदाहरण का उपयोग करना:https://msdn.microsoft.com/en -us/लाइब्रेरी/938d9dz2.aspx ।
यह दिखाता है कि किसी प्रोजेक्ट में ट्रिगर कैसे चलाया जाए और CLR ऑब्जेक्ट को कैसे कॉल किया जाए।
प्रभावी रूप से, आपकी परियोजना में, आप एक ट्रिगर बनाते हैं और इसे अपनी कक्षा कहते हैं।
लाइन पर ध्यान दें:[SqlTrigger(Name="UserNameAudit", Target="Users", Event="FOR INSERT")]
यह परिभाषित करता है कि जब कोड सक्रिय होता है, तो कोड के भीतर, आप अपनी बाधा की जांच कर सकते हैं, फिर शेष विधि (या नहीं) को सक्रिय कर सकते हैं, या किसी अन्य object.method को कॉल कर सकते हैं। जैसी जरूरत थी।
सीधे डीबी पर जाने और ट्रिगर जोड़ने के बीच प्राथमिक अंतर यह है कि यह आपको एक साथ तैनात किए जाने पर आपके प्रोजेक्ट में सभी ऑब्जेक्ट्स तक पहुंच प्रदान करता है।