यह पोस्ट in MVC/MVP/MVPC where do you put your business logic? के समान है, लेकिन मैं अधिक जानकारी के लिए देख रहा हूं। मैंने मॉडल में उस स्थान के रूप में खरीदा है जहां व्यापार तर्क का विशाल बहुमत निवास करना चाहिए। हालांकि, जहां तक मैं समझता हूं, मॉडल में इसके अंदर बहुत कुछ चल रहा है: आवेदन राज्य प्रबंधन, डेटा दृढ़ता, भंडार, डेटा स्थानांतरण वस्तुओं, और संभवतः अन्य सामान।एमवीसी/एमवीपी/एमवीवीएम - व्यवसाय तर्क को व्यवस्थित करने के लिए कैसे करें
मेरे पास एक ऐसा एप्लिकेशन है जिसमें सुपर जटिल व्यवसाय नियम हैं। जब उपयोगकर्ता किसी दृश्य में एक निश्चित कार्रवाई करने का प्रयास करता है, तो लगभग 20 अलग-अलग नियम होते हैं जिन्हें सत्यापित करना चाहिए कि क्या कार्रवाई की अनुमति दी जानी चाहिए, या क्या उपयोगकर्ता को अतिरिक्त जानकारी के लिए संकेत दिया जाना चाहिए। मैं टेस्टेबिलिटी और दस्तावेज़ीकरण का समर्थन करने के लिए इन व्यवसाय नियमों को एक-प्रति-विधि कोड करना चाहता हूं। क्या ये नियम एक भंडार वर्ग में होना चाहिए? शायद भंडारों के ऊपर एक सेवा परत में? यह ध्यान में रखते हुए सबसे अच्छा अभ्यास क्या है कि मैं लिंक से SQL, EF, या nHibernate जैसे ओआरएम समाधान का उपयोग कर रहा हूं?
मैं जवाब की सराहना करते हैं, लेकिन मैं NUnit या किसी अन्य परीक्षण ढांचे, के साथ इन तरीकों का परीक्षण करने में सक्षम होना चाहते और नियमों डाल डेटाबेस में यह और अधिक कठिन बना देगा। – Andy
साथ ही, इन नियमों की जटिलता के साथ, डेटाबेस में उन सभी को प्रबंधित करना बेहद मुश्किल हो जाएगा। – Andy