ज्यादातर मामलों में मैं एक सामान्यीकृत स्कीमा
का उपयोग करूंगा। एक टेबल के साथ option_tag तालिकाओं के बीच कई-से-अनेक संबंध लागू करना option और tag . संदर्भ कार्यान्वयन यहां:
यह हर लिहाज से सबसे तेज़ विकल्प नहीं हो सकता है, लेकिन यह संदर्भात्मक अखंडता, बाधाओं, डेटा प्रकारों की पूरी श्रृंखला, सभी इंडेक्स विकल्प और सस्ते अपडेट सहित डीबी कार्यक्षमता की पूरी श्रृंखला प्रदान करता है।
पूर्णता के लिए, अपने विकल्पों की सूची में जोड़ें:
hstore(अच्छा विकल्प)xmlhstore. की तुलना में अधिक क्रियात्मक और अधिक जटिल याjsonb, इसलिए मैं इसका उपयोग केवल XML के साथ संचालन करते समय करूंगा।- "अल्पविराम द्वारा अलग किए गए मानों की स्ट्रिंग" (बहुत ही सरल, अधिकतर खराब विकल्प)
- ईएवी (इकाई-विशेषता-मूल्य) या "नाम-मूल्य जोड़े" (ज्यादातर खराब विकल्प)
dba.SE पर इस संबंधित प्रश्न के तहत विवरण:
यदि सूची केवल प्रदर्शन के लिए है और शायद ही कभी अपडेट की जाती है, तो मैं एक सादे सरणी पर विचार करूंगा, जो आम तौर पर छोटी होती है और बाकी की तुलना में इसके लिए बेहतर प्रदर्शन करती है।
पढ़ें जोश बर्कस की ब्लॉग प्रविष्टि @a_horse उनकी टिप्पणी में जुड़ा हुआ है। लेकिन ध्यान रखें कि यह चयनित पठन मामलों पर केंद्रित है। जोश मानते हैं:
और यहीं पर सामान्यीकृत दृष्टिकोण बड़ी जीत हासिल करता है, खासकर जब आप समवर्ती लोड के तहत एकल टैग को बहुत अधिक बदलते हैं।
jsonb यदि आप वैसे भी JSON के साथ काम करने जा रहे हैं, तो केवल एक अच्छा विकल्प है, और JSON "जैसा है" को संग्रहीत और पुनर्प्राप्त कर सकते हैं।