NHibernate - संग्रह मानचित्रण
इस अध्याय में, हम संग्रह का प्रतिनिधित्व करने के तरीके को कवर करेंगे। विभिन्न प्रकार के संग्रह हैं जिन्हें हम NHibernate के भीतर उपयोग कर सकते हैं जैसे कि -
- Lists
- Sets
- Bags
अब, .NET परिप्रेक्ष्य से, हम आम तौर पर सूचियों से निपटते हैं या बहुत ही सरल डेटा संरचनाओं, सूचियों, शब्दकोशों की तरह। .NET में विभिन्न प्रकार के संग्रह की एक विस्तृत विविधता नहीं है। तो NHibernate को इन सभी विभिन्न प्रकारों की आवश्यकता क्यों है? यह वास्तव में डेटाबेस में वापस आता है।
सूची
एक सूची उन तत्वों का एक संग्रहित संग्रह है जो आवश्यक रूप से अद्वितीय नहीं हैं।
हम इसका उपयोग करके नक्शा कर सकते हैं IList <T>।
इसलिए यद्यपि हमारे पास पारंपरिक रूप से पते की एक सूची हो सकती है, और आवेदन के दृष्टिकोण से हम जानते हैं कि तत्व अद्वितीय हैं, सूची में कुछ भी हमें उस सूची में डुप्लिकेट तत्वों को सम्मिलित करने से नहीं रोकता है।
सेट
एक सेट अद्वितीय तत्वों का एक अनियंत्रित संग्रह है। यदि आप एक सेट में 2 डुप्लिकेट तत्वों को सम्मिलित करने का प्रयास करते हैं, तो यह एक अपवाद फेंक देगा।
इसके बारे में NHibernate में कुछ खास नहीं है।
यह सिर्फ एक सुविधाजनक तरीका है एक सामान्य सेट कार्यान्वयन है। यदि आप .NET 4 पर हैं, तो आप नए का उपयोग कर सकते हैंHashSet <T> इनका प्रतिनिधित्व करने के लिए, लेकिन अधिकांश NHibernate अनुप्रयोगों में, हम प्रतिनिधित्व करते हैं कि यह एक ISet है।
यह एक अनियंत्रित है, यदि आप डेटाबेस से पतों की एक सूची या आदेशों की सूची को वापस खींचते हैं, तो आप नहीं जानते कि वे तब तक किस क्रम में आ रहे हैं जब तक कि आप किसी विशिष्ट क्रम में खंड द्वारा नहीं डालते हैं।
तो सामान्य तौर पर, आप जिस डेटा को डेटाबेस से वापस खींच रहे हैं वह सेट है।
वे तत्वों के अनूठे संग्रह हैं जो अनियंत्रित हैं।
बैग
एक और आम संग्रह जो हम डेटाबेस की दुनिया में देखेंगे, वह एक बैग है, जो एक सेट की तरह है सिवाय इसके कि इसमें डुप्लिकेट तत्व हो सकते हैं।
.NET की दुनिया में, हम एक IList द्वारा इसका प्रतिनिधित्व करते हैं।
सेट शायद सबसे आम हैं, लेकिन आप अपने आवेदन के आधार पर सूची और बैग देखेंगे। नीचे एक नजर डालते हैंcustomer.hbm.xml अंतिम अध्याय से फ़ाइल जिसमें सेट आदेश परिभाषित किए गए हैं।
<?xml version = "1.0" encoding = "utf-8" ?>
<hibernate-mapping xmlns = "urn:nhibernate-mapping-2.2" assembly = "NHibernateDemo"
namespace = "NHibernateDemo">
<class name = "Customer">
<id name = "Id">
<generator class = "guid.comb"/>
</id>
<property name = "FirstName"/>
<property name = "LastName"/>
<property name = "AverageRating"/>
<property name = "Points"/>
<property name = "HasGoldStatus"/>
<property name = "MemberSince" type = "UtcDateTime"/>
<property name = "CreditRating" type = "CustomerCreditRatingType"/>
<component name = "Address">
<property name = "Street"/>
<property name = "City"/>
<property name = "Province"/>
<property name = "Country"/>
</component>
<set name = "Orders" table = "`Order`">
<key column = "CustomerId"/>
<one-to-many class = "Order"/>
</set>
</class>
</hibernate-mapping>
जैसा कि आप देख सकते हैं, हमने एक सेट के रूप में ऑर्डर संग्रह को मैप किया है। याद रखें कि एक सेट अद्वितीय तत्वों का एक अनियंत्रित संग्रह है।
अब, यदि आप ग्राहक वर्ग को देखते हैं, तो आप देखेंगे कि आदेश संपत्ति को एक आईएसईटी के साथ परिभाषित किया गया है जैसा कि निम्नलिखित कार्यक्रम में दिखाया गया है।
public virtual ISet<Order> Orders { get; set; }
अब जब यह एप्लिकेशन चलाया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।
New Customer:
John Doe (00000000-0000-0000-0000-000000000000)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Unspecified)
CreditRating: Good
AverageRating: 42.42424242
Orders:
Order Id: 00000000-0000-0000-0000-000000000000
Order Id: 00000000-0000-0000-0000-000000000000
Reloaded:
John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7
The orders were ordered by:
John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7
John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7
Press <ENTER> to exit...
यदि संग्रह में मौजूद वस्तुओं को विशिष्ट होने की आवश्यकता नहीं है, यदि आपके पास इस संग्रह में कई बार होने वाली एक ही प्राथमिक कुंजी के साथ कई आदेश हो सकते हैं, तो यह एक बैग के रूप में बेहतर मैप किया जाएगा जैसा कि निम्नलिखित कार्यक्रम में दिखाया गया है।
<bag name = "Orders" table = "`Order`">
<key column = "CustomerId"/>
<one-to-many class = "Order"/>
</bag>
अब, यदि आप इस एप्लिकेशन को चलाते हैं, तो आपको एक अपवाद मिलेगा क्योंकि यदि हम ग्राहक वर्ग पर एक नज़र डालते हैं, तो आप देखेंगे कि आदेश सी # कोड में एक आइएसटी के रूप में चिह्नित हैं।
इसलिए हमें इसे एक IList में बदलना होगा और फिर यहां, हमें HashSet से एक सूची में कंस्ट्रक्टर में बदलना होगा।
public class Customer {
public Customer() {
MemberSince = DateTime.UtcNow;
Orders = new List<Order>();
}
public virtual Guid Id { get; set; }
public virtual string FirstName { get; set; }
public virtual string LastName { get; set; }
public virtual double AverageRating { get; set; }
public virtual int Points { get; set; }
public virtual bool HasGoldStatus { get; set; }
public virtual DateTime MemberSince { get; set; }
public virtual CustomerCreditRating CreditRating { get; set; }
public virtual Location Address { get; set; }
public virtual IList<Order> Orders { get; set; }
public virtual void AddOrder(Order order) { Orders.Add(order); order.Customer = this; }
public override string ToString() {
var result = new StringBuilder();
result.AppendFormat("{1} {2} ({0})\r\n\tPoints: {3}\r\n\tHasGoldStatus:
{4}\r\n\tMemberSince: {5} ({7})\r\n\tCreditRating: {6}\r\n\tAverageRating:
{8}\r\n", Id, FirstName, LastName, Points, HasGoldStatus, MemberSince,
CreditRating, MemberSince.Kind, AverageRating); result.AppendLine("\tOrders:");
foreach(var order in Orders) {
result.AppendLine("\t\t" + order);
}
return result.ToString();
}
}
जब आप एप्लिकेशन चलाते हैं, तो आपको वही व्यवहार दिखाई देगा। लेकिन, अब हमारे पास एक ही संग्रह में कई बार होने वाला एक आदेश हो सकता है।
John Doe (00000000-0000-0000-0000-000000000000)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Unspecified)
CreditRating: Good
AverageRating: 42.42424242
Orders:
Order Id: 00000000-0000-0000-0000-000000000000
Order Id: 00000000-0000-0000-0000-000000000000
Reloaded:
John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287
The orders were ordered by:
John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287
John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
Points: 100
HasGoldStatus: True
MemberSince: 1/1/2012 12:00:00 AM (Utc)
CreditRating: Good
AverageRating: 42.4242
Orders:
Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287
Press <ENTER> to exit...