मुझे लगता है कि आपको डेटाबेस सामान्यीकरण के बारे में पढ़ना चाहिए। और अपने लिए फैसला करो। हालांकि संक्षेप में, आपके प्रस्ताव में कई समस्याएं हैं, लेकिन आप तय कर सकते हैं कि आप उनके साथ रह सकते हैं।
सबसे स्पष्ट हैं:
- क्या होगा यदि पंक्ति(1) में एक अतिरिक्त टैग जोड़ा जाए? क्या आपको पहले पार्स करना है, जांचें कि यह पहले से मौजूद है या नहीं, फिर पंक्ति को
tags.append(newTag)
के रूप में अपडेट करें । - किसी टैग को हटाना अभी भी बदतर है? टैग खोजें, मौजूद है, टैग फिर से बनाएं।
- क्या होगा यदि किसी टैग को नाम बदलना है - कुछ मॉडरेशन प्रक्रिया, शायद?
- इससे भी बुरी बात यह है कि अलग-अलग लोग किसी टैग-नाम को अलग-अलग तरीके से निर्दिष्ट करते हैं - इसे युक्तिसंगत बनाना कठिन होगा।
- यदि आप टैग के आधार पर डेटा क्वेरी करना चाहते हैं तो क्या होगा? आपकी क्वेरी जितनी जटिल होनी चाहिए, उससे कहीं अधिक जटिल हो जाती है।
- प्रस्तुति:क्लाइंट को टैग का उपयोग करने के लिए उसे पार्स करना होगा। विभाजक क्षेत्र के बारे में क्या? इसे बदलें और सभी क्लाइंट को बदलना होगा।
संक्षेप में, ये सभी ऑपरेशन कठिन और अधिक बोझिल हो जाते हैं। सामान्यीकरण ऐसे मुद्दों को दूर करने के लिए डिज़ाइन किया गया है। संभवतः आप जो कहते हैं, उसे करने का एकमात्र कारण, IMO, यह है कि आप डेटा को एक बार के रूप में कैप्चर कर रहे हैं और यह केवल सूचनात्मक है - अर्थात, उपयोगकर्ता के लिए समझ में आता है, लेकिन सिस्टम प्रति-से नहीं। यह कहने की तरह है कि यह शायद सबसे अच्छा बचा है (फिर से, आईएमओ)।