Database
 sql >> डेटाबेस >  >> RDS >> Database

एकीकृत परिवहन डेटा मॉडल

एकीकृत परिवहन एक ऐसी चीज है जिसके बारे में हम अक्सर इंटरनेट या समाचारों में सुनते हैं। हालांकि यह कुछ नया नहीं है, यह निश्चित रूप से एक सतत प्रक्रिया है, जिसमें निरंतर परिवर्तन लागू किए जा रहे हैं। आज, हम एक डेटा मॉडल पर एक नज़र डालेंगे जो ज़ोन, यात्री और टिकट की जानकारी को संभाल सकता है।

आइए हम अपने एकीकृत परिवहन डेटा मॉडल की खोज करें, इसके पीछे के विचार से शुरू करें।

विचार

इसकी दक्षता को अधिकतम करने के लिए और ग्राहकों के लिए, इसके आसान उपयोग के लिए परिवहन को एकीकृत करना आवश्यक है। एकीकरण लागत से संबंधित है लेकिन समय, पहुंच, आराम और सुरक्षा से भी संबंधित है। यह बड़े शहरों के साथ-साथ छोटे शहरों पर भी लागू होता है। विचार मौजूदा परिवहन बुनियादी ढांचे का उपयोग करना और बेहतर परिणामों के लिए इसे अनुकूलित करना है; इसका मतलब नए शेड्यूल, नोटिफिकेशन, लाइन या स्टेशन के साथ आना हो सकता है। हो सकता है कि बस के लिए प्रतीक्षा करने, साइकिल किराए पर लेने, या बस अपने गंतव्य तक पैदल चलने का निर्णय लेने के लिए बस कुछ जानकारी होना ही पर्याप्त हो।

आइए इसे दो उदाहरणों से समझाएं।

एक बड़े शहर के मामले में, आमतौर पर परिवहन के कई अलग-अलग साधन उपलब्ध होते हैं:बसें, टैक्सी, ट्राम, रेलवे, भूमिगत, आदि। इससे कई अलग-अलग निजी कंपनियां विभिन्न परिवहन सेवाएं प्रदान कर सकती हैं। इनमें से कुछ सेवाओं के संयोजन से निश्चित रूप से यात्रियों और कंपनियों को लागत कम करने, दक्षता बढ़ाने और प्रति टिकट अधिक सेवा प्रदान करने से लाभ होगा।

एक छोटे शहर के लिए भी इसी तरह के लाभ हैं। गठबंधन करने के लिए समान संख्या में विकल्प नहीं हो सकते हैं, लेकिन अधिकतम दक्षता प्राप्त करने के लिए उन्हें व्यवस्थित किया जा सकता है।

यह लेख मुख्य रूप से एकीकृत परिवहन टिकट प्रणाली पर केंद्रित होगा। हम एकीकरण के सभी पहलुओं और विभिन्न प्रकार के परिवहन पर ध्यान केंद्रित नहीं करेंगे; यह बहुत जटिल होगा।

इसे ध्यान में रखते हुए, आइए अपने मॉडल पर चलते हैं।

डेटा मॉडल

मॉडल में दो विषय क्षेत्र शामिल हैं:

  • Cities & companies
  • Tickets

हम उनका वर्णन उसी क्रम में करेंगे जिस क्रम में वे सूचीबद्ध हैं।

शहर और कंपनियां

पहले विषय क्षेत्र में, हम शहरों में परिवहन क्षेत्र स्थापित करने के लिए आवश्यक सभी तालिकाओं को संग्रहीत करेंगे।

country तालिका में UNIQUE की एक सूची है country_name मूल्य। इस तालिका का उपयोग केवल city टेबल। जबकि हम उम्मीद कर सकते हैं कि हमारा मॉडल केवल एक देश में परिवहन को कवर करेगा, हम कई देशों को शामिल करने का विकल्प चाहते हैं। प्रत्येक शहर के लिए, हम UNIQUE संयोजन city_name . संग्रहित करेंगे - country_id .

छोटे शहरों में शायद एक ही जोन होगा, जबकि बड़े शहरों में कई जोन होंगे। सभी संभावित क्षेत्रों की सूची zone टेबल। प्रत्येक ज़ोन के लिए, हम उसका zone_name स्टोर करेंगे और संबंधित शहर के लिए एक संदर्भ। यह जोड़ी इस तालिका की वैकल्पिक कुंजी बनाती है।

हम उम्मीद कर सकते हैं कि हमारा सिस्टम कई परिवहन कंपनियों के बारे में जानकारी संग्रहीत करेगा। कंपनियां अपने खुद के टिकट जारी करेंगी, लेकिन वे अन्य कंपनियों के साथ संयुक्त रूप से टिकट भी जारी कर सकेंगी। प्रत्येक company , हम company_name . के UNIQUE संयोजन को संग्रहित करेंगे और city_id जहाँ यह स्थित है। किसी भी आवश्यक अतिरिक्त जानकारी को शाब्दिक details . में संग्रहीत किया जा सकता है फ़ील्ड.

आखिरी चीज जिसे हमें परिभाषित करने की आवश्यकता है वह है परिवहन का रूप जो प्रत्येक कंपनी प्रदान करती है। कुछ अपेक्षित मान "बस", "ट्राम", "भूमिगत" और "रेलवे" हैं। transport_form तालिका, हम UNIQUE form_name संग्रहीत करेंगे।

  • zone_id - zone तालिका और उस क्षेत्र को दर्शाता है जहां इस कंपनी द्वारा परिवहन का यह रूप प्रदान किया जाता है।
  • company_id - संदर्भ company इस क्षेत्र में यह सेवा प्रदान करना।
  • transport_form_id - transport_form तालिका और प्रदान की गई सेवा के प्रकार को दर्शाता है।
  • date_from और date_to - जिस अवधि के दौरान इस कंपनी द्वारा यह सेवा प्रदान की गई थी। ध्यान दें कि date_to यदि यह सेवा अभी भी उपलब्ध है और/या इसकी कोई अपेक्षित समाप्ति तिथि नहीं है, तो इसमें NULL मान हो सकता है।
  • details - अन्य सभी विवरण, एक असंरचित पाठ्य प्रारूप में।
  • is_active - यदि यह सेवा सक्रिय है (चल रही है) या नहीं। यह एक आसान ऑन/ऑफ स्विच है जिसका उपयोग हम कुछ मामलों में date_from . के बजाय कर सकते हैं - date_to सेवा गतिविधि अंतराल। इस विशेषता का सबसे अच्छा उपयोग प्रश्नों को सरल बनाना होगा, यानी दिनांक अंतराल का परीक्षण करने और NULL मानों के साथ "खेलने" के बजाय इस मान का परीक्षण करके।

टिकट

पिछला विषय क्षेत्र सिर्फ मुख्य चीज की तैयारी था:टिकट। और इस विषय क्षेत्र में यही शामिल होगा।

हमने कंपनियों, क्षेत्रों और परिवहन रूपों को परिभाषित किया है, लेकिन हमारे पास यात्रियों और टिकटों के लिए कोई प्रावधान नहीं है - इस मॉडल का मूल। हम मान लेंगे कि एक टिकट का उपयोग एक या अधिक कंपनियों द्वारा कवर किए गए एक या अधिक क्षेत्रों के लिए किया जा सकता है।

इसलिए, हमें पहले प्रत्येक ticket_type . इस तालिका में, हम अपने डेटाबेस में कंपनियों द्वारा बेचे जा रहे सभी संभावित प्रकार के टिकटों को सूचीबद्ध करेंगे। प्रत्येक प्रकार के लिए, हम निम्नलिखित मान संग्रहीत करेंगे:

  • type_name - इस प्रकार को विशिष्ट रूप से दर्शाने वाला एक नाम।
  • valid_from और valid_to - वह अवधि जब यह टिकट प्रकार वैध है (या था)। दोनों फ़ील्ड अशक्त हैं; एक NULL मान का अर्थ है कि यह कब मान्य था इसके लिए कोई आरंभ (या समाप्ति) तिथि नहीं है।
  • details - कोई भी आवश्यक विवरण, असंरचित पाठ्य प्रारूप में।
  • recurring - एक ध्वज यह दर्शाता है कि यह टिकट प्रकार आवर्ती है (जैसे वार्षिक, मासिक) या नहीं।
  • interval_month - अगर टिकट का प्रकार आवर्ती है, तो इस विशेषता में महीनों में अंतराल होगा, जब इसकी पुनरावृत्ति होगी (उदाहरण के लिए मासिक टिकट के लिए "1", वार्षिक टिकट के लिए "12")।

अब हम प्रत्येक टिकट प्रकार द्वारा कवर किए गए क्षेत्रों को परिभाषित करने के लिए तैयार हैं। service_included तालिका में, हम केवल UNIQUE युग्म संग्रहीत करेंगे ticket_type_id - service_available_id . उत्तरार्द्ध कंपनी और उस क्षेत्र को भी इंगित करेगा जहां इस टिकट का उपयोग किया जा सकता है। यह तालिका हमें प्रति टिकट कई क्षेत्रों को परिभाषित करने की अनुमति देती है; क्षेत्र विभिन्न कंपनियों के हो सकते हैं। चूंकि ये पूर्वनिर्धारित टिकट प्रकार हैं, इसलिए प्रत्येक टिकट प्रकार में यहां परिभाषित क्षेत्र होंगे (प्रत्येक व्यक्तिगत यात्री के लिए नहीं)।

हम इस मॉडल में बहुत अधिक यात्री विवरण संग्रहीत नहीं करेंगे। प्रत्येक passenger , हम केवल उनका first_name संग्रहित करेंगे , last_name , address , और उस शहर का संदर्भ जहां वे रहते हैं। यह सारा डेटा टिकट पर प्रदर्शित किया जाएगा।

हमारे मॉडल में अंतिम तालिका है Tickets टेबल। हम यहां एकल-उपयोग वाले टिकटों पर ध्यान केंद्रित नहीं करेंगे; इसके बजाय, हम सब्सक्रिप्शन और प्रीपेड टिकटों का प्रबंधन करेंगे। इन टिकटों में बैलेंस, वैलिडिटी डेट या दोनों होंगे। यह कंपनी और उसके नियमों के आधार पर काफी भिन्न हो सकता है। यदि कुछ कंपनियां टिकट जारी करने का निर्णय लेती हैं, तो हम इस तालिका में इसका समर्थन कर सकते हैं - हम सभी महत्वपूर्ण विवरण जानेंगे। प्रत्येक टिकट के लिए, हम स्टोर करेंगे:

  • serial_number - प्रत्येक टिकट के लिए एक अद्वितीय पदनाम। यह संख्याओं और अक्षरों का संयोजन हो सकता है।
  • ticket_type_id - उस टिकट के प्रकार का संदर्भ देता है।
  • passenger_id - उस यात्री को संदर्भित करता है, यदि कोई हो, जो उस टिकट का मालिक है। प्रीपेड टिकट के मामले में, कोई मालिक नहीं हो सकता है।
  • valid_from और valid_to - उस अवधि को दर्शाता है जिसके दौरान यह टिकट वैध है। NULL मान दर्शाता है कि कोई निचली या ऊपरी सीमा नहीं है।
  • credits - उस टिकट पर वर्तमान में उपलब्ध क्रेडिट (संख्यात्मक मान के रूप में)। अगर यह प्रीपेड टिकट है, तो हम मान सकते हैं कि यात्री टिकट पर अतिरिक्त क्रेडिट खरीदेंगे। यदि टिकट पूरे महीने (या किसी अन्य समय अवधि) के दौरान उपयोग की किसी सीमा के बिना वैध है, तो यह मान शून्य हो सकता है।

एकीकृत परिवहन डेटा मॉडल में सुधार

आप देख सकते हैं कि इस मॉडल को बहुत सरल बनाया गया है। ऐसा इसलिए है क्योंकि एकीकृत परिवहन एक लेख में शामिल होने के लिए बहुत बड़ा है। कुछ चीजें हैं जो मुझे लगता है कि इस मॉडल में बदली जा सकती हैं:

  • क्षेत्र बहुत सरल हैं; हमें उन्हें अधिक गतिशील रूप से परिभाषित करने में सक्षम होना चाहिए।
  • हम लाइनों (जैसे बस लाइन) को कवर नहीं करते हैं। क्या होगा यदि वे एक क्षेत्र से दूसरे क्षेत्र में जाते हैं, आदि?
  • हम टिकट उपयोग के इतिहास को संग्रहीत नहीं करते हैं।
  • कंपनियों और यात्रियों के लिए कोई पंजीकरण नहीं है।

ये सभी इस तथ्य की ओर ले जाएंगे कि हमारे पास महत्वपूर्ण डेटा की कमी है और हम कोई गहरा विश्लेषण नहीं कर सकते। तो आप क्या सोचते हैं? इस मॉडल को क्या चाहिए? आप क्या जोड़ेंगे या हटाएंगे? टिप्पणियों में अपने विचार साझा करें।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Azure SQL डेटाबेस में स्वचालित अनुक्रमणिका प्रबंधन

  2. यूनीवर्स टिप्स

  3. अनुक्रमणिका प्राप्त करने का एक तरीका अग्रणी %वाइल्डकार्ड की तलाश करें

  4. ट्यूनिंग:शुरू करने के लिए एक अच्छी जगह

  5. एक कस्टम प्रकार लागू करना