Fluent-NHibernate : how to map one-to-many relationship into 3 tables (many-to-many, kinda) -


मुझे इस तरह 2 संस्थाएं हैं:

  class A {int id {get; सेट; } स्ट्रिंग का नाम {get; सेट; }} वर्ग बी {int आईडी {get; सेट; } एक रिफोटा {प्राप्त करें; सेट; } स्ट्रिंग का नाम {get; सेट; }}  

मैं इस 2 वर्गों को कैसे मैप कर सकता हूं ताकि मेरे पास इस तरह 3 टेबल हों:

  • 2 कॉलम के साथ तालिका ए: id और नाम

  • 2 स्तंभों के साथ तालिका बी: आईडी और नाम

  • 2 स्तंभों के साथ तालिका एबी: एआईडी और बीआईडी ​​

अगर मैं यह सही समझता हूँ तो आप एक रेफरी टेबल बना रहे हैं क्योंकि आप चाहते हैं नल होने के संदर्भ यदि ऐसा मामला है, तो आपको एक रेफरी टेबल की ज़रूरत नहीं है बस तालिका ख के रूप में एफबी में नल योग्य सेट करें उसके बाद आप इसे एक साधारण संदर्भ मानचित्रित कर सकते हैं। 2 टेबल के साथ तालिका ए: आईडी और नाम

  • 2 स्तंभों के साथ तालिका बी: आईडी, नाम और सहायता (नल योग्य)

    • Li>

    और आप इसे इस तरह से मैप कर सकते हैं:

      सार्वजनिक वर्ग एएमएपी: क्लासमार्क & lt; ए & gt; {सार्वजनिक एएमपी () {आईडी (x = & gt; x.Id); मानचित्र (x = & gt; x.Name); }} सार्वजनिक वर्ग BMAP: क्लासमार्क & lt; B & gt; {सार्वजनिक BMAP () {आईडी (x = & gt; x.Id); मानचित्र (x = & gt; x.Name); संदर्भ (x = & gt; x.RefToA); }}  

    अपडेट

    इस पर नज़र रखने का कोई तरीका नहीं है कि आप कैसे निहलनात्मक (और उस बात के लिए कोई अन्य orm) में नहीं चाहते हैं। इसके लिए कारण काफी सरल है: यह कुछ नियमों का उल्लंघन करता है और इस तरह से ऐसा करने का कोई कारण नहीं है। ऐसा करने के लिए सही तरीके से तालिका बी में एक रिक्त fk संदर्भ होना चाहिए इसी तरह आप एक एसक्यूएल डेटाबेस में एक संदर्भ का प्रतिनिधित्व करते हैं जब आप एक-से-कई मानते हैं और यह निश्चित रूप से बाद में आपको परेशानी देगी तो कई-से-कई लोगों का उपयोग करने के लिए यह केवल खराब डिजाइन है।


  • Comments

    Popular posts from this blog

    c# - TypeConverter in propertygrid only converts from string, not to -

    php - multilevel menu with multilevel array -

    jQuery UI: Datepicker month format -