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

एक रेस्तरां वितरण डेटा मॉडल

भूख लगी है लेकिन आप खाना नहीं बनाना चाहते हैं? एक रेस्तरां को कॉल करें, अपना पसंदीदा भोजन ऑर्डर करें, और एक डेटा मॉडल के बारे में पढ़ें जो पूरी प्रक्रिया को व्यवस्थित कर सकता है।

"समय बचाने वाली" तकनीक की प्रचुरता के बावजूद, हमारे पास खाने जैसी बुनियादी ज़रूरतों को पूरा करने के लिए कम समय लगता है। अगर हम कुछ खाना चाहते हैं, लेकिन हमारे पास खुद पकाने के लिए समय (या कौशल) नहीं है, तो हम एक रेस्तरां (यानी टेकअवे या टेकआउट) से खाना मंगवा सकते हैं, जो हमारे भोजन को हमारे दरवाजे पर लाएगा। बेशक, हमें इस सुविधा के लिए भुगतान करना होगा, इसलिए हम उम्मीद करते हैं कि खाना अच्छा और गर्म हो!

जाहिर है, कोई भी रेस्तरां अपने ग्राहकों को संतुष्ट रखने के लिए प्रेरित होता है। आपको यह जानकर आश्चर्य हो सकता है कि टेकअवे चलाने में कितना काम लगता है। अधिकांश ऑर्डर और डिलीवरी को प्रबंधित करने के लिए किसी न किसी प्रकार के ट्रैकिंग सिस्टम का उपयोग करते हैं। आइए ऐसी ही एक प्रणाली के तहत डेटा मॉडल को देखें। अपने लिए एक नाश्ता लें, वापस बैठें और लेख का आनंद लें।

रेस्तरां व्यवसाय के बारे में हमें क्या पता होना चाहिए?

खाना बनाना और ग्राहकों तक पहुंचाना आसान नहीं है। स्वादिष्ट भोजन तैयार करने के लिए सबसे पहले आपके पास प्रतिभा और ज्ञान होना चाहिए। आपको व्यवस्थित होने की भी आवश्यकता है:अगर ये भोजन समय पर और सही जगह पर पहुंचाए जा रहे हैं तो सब कुछ पूरी तरह से काम करने की जरूरत है!

इससे पहले कि हम कोई भी भोजन देना शुरू करें, हमें यह जानना होगा:

  • भोजन का आदेश किसने दिया
  • भोजन कहां और कब दिया जाना चाहिए
  • आदेश में कौन से व्यंजन शामिल हैं
  • आदेश को पूरा करने के लिए हमें किन सामग्रियों की आवश्यकता है
  • यदि आदेश का भुगतान पहले ही किया जा चुका है

हमें डिलीवरी की स्थिति को ट्रैक करने और उनके भोजन और/या हमारी डिलीवरी प्रक्रिया के बारे में ग्राहकों की प्रतिक्रिया रिकॉर्ड करने की भी आवश्यकता है। इसके अलावा, शायद हम जानना चाहते हैं कि कौन से भोजन सबसे अधिक (या कम से कम) लोकप्रिय हैं। और हमें कुछ वित्तीय जानकारी भी रिपोर्टिंग और विश्लेषण उद्देश्यों के लिए रखनी चाहिए।

आइए मान लें कि हमारे पास एक ऐप है जिसका उपयोग हमारे ग्राहक डिलीवरी के लिए ऑर्डर देने के लिए कर सकते हैं। यह उन्हें मेनू आइटम चुनने, उनके लिए भुगतान करने और डिलीवरी का समय और पता निर्दिष्ट करने की अनुमति देता है। ऐसे ऐप के नीचे डेटा मॉडल कैसा दिख सकता है?

डेटा मॉडल




आप Edit model in your browser . पर क्लिक करके इस मॉडल को अपने ब्राउज़र में खोल सकते हैं बटन।

डेटा मॉडल में तीन विषय क्षेत्र होते हैं:

  • Restaurants & customers
  • Menus
  • Orders

हम प्रत्येक विषय क्षेत्र को सूचीबद्ध क्रम में प्रस्तुत करेंगे।

रेस्तरां और ग्राहक

Restaurants & customers विषय क्षेत्र में तीन टेबल होते हैं जो हमारे रेस्तरां (एक से अधिक हो सकते हैं), जिन शहरों में हम काम करते हैं, और हमारे ग्राहकों के बारे में विवरण संग्रहीत करते हैं।

ग्राहक और रेस्तरां दोनों शहरों (या कस्बों, गांवों, आदि) में स्थित हैं। इसलिए, हमें एक city शब्दकोश। इसमें केवल दो विशेषताएँ हैं, city_name और zip_code . अगर हम एक से अधिक देशों में काम करते हैं, तो हमें एक देश शब्दकोश की भी आवश्यकता होगी जो इस तालिका से संबंधित हो, लेकिन हम यहां उस पर नहीं जाएंगे।

इसके बाद, हमें उन सभी रेस्तरां की एक सूची चाहिए जो हम संचालित करते हैं। हम restaurant उसके लिए तालिका। चीजों को सरल रखने के लिए, हम केवल प्रत्येक रेस्तरां का address संग्रहित करेंगे और city यह कहाँ स्थित है।

इस विषय क्षेत्र में अंतिम तालिका customer टेबल। यह वह जगह है जहां हम अपने सभी पंजीकृत डिलीवरी ग्राहकों की एक सूची संग्रहित करेंगे। हम बाद में मॉडल में ग्राहकों को उनके ऑर्डर से जोड़ने के लिए इस तालिका के डेटा का उपयोग करेंगे। बेशक, ऑर्डर देने के लिए ग्राहकों को हमारे मॉडल में पंजीकृत होने की आवश्यकता नहीं है, लेकिन हमें अभी भी इस सूची की आवश्यकता है। हम लॉयल्टी प्रोग्राम के रूप में पंजीकृत ग्राहकों को छूट प्रदान कर सकते हैं। या शायद हम इस डेटा का उपयोग विशेष ऑफ़र वाले ग्राहकों से संपर्क करने के लिए करेंगे। प्रत्येक पंजीकृत ग्राहक के लिए, हम स्टोर करेंगे:

  • customer_name - ग्राहक का पूरा नाम।
  • city_id - संदर्भ city जहां ग्राहक रहता है।
  • address - ग्राहक का पता।
  • contact_phone - ग्राहक का फोन नंबर।
  • email - पंजीकरण प्रक्रिया के दौरान ग्राहक द्वारा उपयोग किया गया ईमेल पता।
  • confirmation_code - पंजीकरण प्रक्रिया के दौरान उपयोग किया जाने वाला एक पुष्टिकरण कोड।
  • password - इस ऐप के लिए ग्राहक द्वारा चुना गया पासवर्ड।
  • time_joined - ग्राहक के हमारे आवेदन में शामिल होने का टाइमस्टैम्प।

मेनू

इस विषय क्षेत्र में हमारे रेस्तरां के मेनू के बारे में जानकारी है। अभी के लिए, मान लें कि हमारे सभी रेस्तरां एक ही मेनू का उपयोग करते हैं।

पहली तालिका है category शब्दकोश। इसमें केवल एक UNIQUE विशेषता है, category_name . इस फ़ील्ड में शायद सामान्य मेनू श्रेणियां होंगी, जैसे "पेय", "शुरुआत", "सलाद", "सैंडविच", "पिज्जा", आदि।

इसके बाद, हमारे पास menu_item टेबल। यह हमारे किसी भी मेनू पर हमारे पास (या था) सभी वस्तुओं को सूचीबद्ध करता है। प्रत्येक आइटम के लिए, हम स्टोर करेंगे:

  • item_name - उस आइटम का नाम, उदा. "चिकन सैंडविच"।
  • category_id - संदर्भ category वह वस्तु जिससे संबंधित है, उदा। "सैंडविच"।
  • description - उस वस्तु का विवरण। यह प्रिंटेड मेन्यू जैसा ही होना चाहिए।
  • ingredients - उस वस्तु को बनाने के लिए प्रयुक्त सामग्री और उनकी मात्रा। यह फ़ील्ड वास्तव में एक नुस्खा संग्रहीत कर सकती है।
  • price - एक आइटम की मौजूदा कीमत (जैसे कि एक चिकन सैंडविच)।
  • active - यदि आइटम वर्तमान मेनू पर पेश किया जाता है।

यदि हम मेनू को कई भाषाओं में संग्रहीत करना चाहते हैं, तो हमें इस लेख में प्रस्तुत दृष्टिकोण की तरह एक दृष्टिकोण का उपयोग करना चाहिए।

अधिकांश रेस्तरां में विशेष, सीमित समय के ऑफ़र होते हैं। उनके पास असीमित समय के लिए कुछ ऑफ़र भी हो सकते हैं। हम offer इनके लिए तालिका। प्रत्येक के लिए, हमारे पास होगा:

  • date_active_from और date_active_to - साथ में, ये परिभाषित करते हैं कि यह ऑफ़र कब सक्रिय है। यदि किसी ऑफ़र की अवधि असीमित है या यदि यह दिनों के बजाय घंटों पर आधारित है, तो इन दो विशेषताओं में NULL मान होंगे। इस प्रकार के ऑफ़र का एक उदाहरण है "मार्च के महीने के दौरान, एक करी खरीदें और एक पर 50% छूट प्राप्त करें"।
  • time_active_from और time_active_to - दिन के उस समय को परिभाषित करता है जब कोई ऑफ़र मान्य होता है - उदा। "हर दिन सुबह 6-9 बजे तक मुफ़्त कॉफ़ी पाएं"।
  • offer_price - उस ऑफ़र की कीमत.

ऑफ़र में शामिल सभी मेनू आइटम in_offer टेबल। इस तालिका में offer_id . की UNIQUE जोड़ी है - menu_item_id

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

आदेश

हमारे मॉडल में अंतिम विषय क्षेत्र है Orders विषय क्षेत्र। यह वह जगह है जहां हमारे पास ऑर्डर और उनकी स्थिति को स्टोर करने के लिए आवश्यक सब कुछ होगा।

यहां केंद्रीय तालिका है placed_order टेबल। इस तालिका के नाम के रूप में केवल "आदेश" का उपयोग नहीं करना सबसे अच्छा है:"आदेश" एक SQL कीवर्ड है। तालिकाओं और स्तंभों के नाम के रूप में कीवर्ड का उपयोग करने से बचने का प्रयास करें; अन्यथा, प्रश्न लिखते समय आपको त्रुटियाँ मिल सकती हैं। प्रत्येक आदेश के लिए, हम रिकॉर्ड करेंगे:

  • restaurant_id - restaurant उस आदेश से संबंधित।
  • order_time - ऑर्डर देने के समय का टाइमस्टैम्प।
  • estimated_delivery_time - इस ऑर्डर की सुनियोजित डिलीवरी का टाइमस्टैम्प।
  • food_ready - एक टाइमस्टैम्प यह दर्शाता है कि ऑर्डर आइटम कब तैयार किए गए थे। भोजन तैयार होने तक इसमें NULL मान होगा। हम इस विशेषता का उपयोग उस समय के अंतर की गणना करने के लिए कर सकते हैं जब ऑर्डर दिया गया था और जब खाना तैयार किया गया था। हम इसका उपयोग यह पता लगाने के लिए भी कर सकते हैं कि भोजन कब तैयार हुआ और कब वितरित किया गया। कर्मचारियों की कार्यकुशलता बढ़ाने के मामले में यह जानकारी बहुत मददगार हो सकती है।
  • actual_delivery_time - एक टाइमस्टैम्प जब यह आदेश वास्तव में वितरित किया गया था। यह तब तक NULL रहेगा जब तक कि ग्राहक को खाना डिलीवर नहीं कर दिया जाता।
  • delivery_address - वह पता जहां ऑर्डर दिया जाना चाहिए।
  • customer_id - customer जिसने यह आदेश दिया। इस विशेषता में एक NULL मान हो सकता है यदि आदेश किसी ऐसे व्यक्ति द्वारा दिया गया था जो एक पंजीकृत ऐप उपयोगकर्ता नहीं है।
  • price - उस क्रम में शामिल सभी वस्तुओं की कीमत।
  • discount - कीमत पर लागू छूट की राशि (जैसे कूपन या लॉयल्टी छूट), यदि कोई हो।
  • final_price - ऑर्डर की कीमत घटाकर छूट।
  • comment - ऑर्डर देते समय ग्राहक द्वारा डाली गई अतिरिक्त टिप्पणियां। यह अतिरिक्त वितरण निर्देश या कुछ और हो सकता है जो ग्राहक को महत्वपूर्ण लगे।
  • ts - एक टाइमस्टैम्प जब यह रिकॉर्ड तालिका में डाला गया था।

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

  • placed_order_id - संबंधित order
  • offer_id - संदर्भ offer तालिका, लेकिन केवल तभी जब इस क्रम में एक या अधिक ऑफ़र शामिल हों। उस स्थिति में, menu_item_id विशेषता NULL होगी।
  • menu_item_id - संदर्भ menu_item तालिका, लेकिन केवल तभी जब यह रिकॉर्ड किसी मेनू आइटम से संबंधित हो, न कि किसी ऑफ़र से।
  • quantity - इस क्रम में कितने ऑफ़र या मेनू आइटम शामिल हैं।
  • item_price - एकल ऑफ़र या मेनू आइटम की कीमत।
  • price – इस लाइन के लिए कुल मूल्य, item_price . के रूप में व्यक्त किया गया है * quantity
  • comment - ग्राहक द्वारा डाली गई कोई भी टिप्पणी जो विशेष रूप से उस ऑर्डर आइटम से संबंधित है, उदा। "कृपया पिज़्ज़ा को 8 स्लाइस में काटें"।

comment तालिका हमें आदेशों से संबंधित कई टिप्पणियों को सम्मिलित करने का समर्थन करने देती है। प्रत्येक टिप्पणी के लिए, हम संबंधित आदेश की आईडी और ग्राहक की आईडी संग्रहीत करेंगे। जब यह टिप्पणी दर्ज की गई थी तब हम उसका टाइमस्टैम्प भी संगृहीत करेंगे। हम यह भी चिन्हित करेंगे कि यह टिप्पणी एक शिकायत थी या प्रशंसा; इन दोनों में से केवल एक को एक बार में सेट किया जा सकता है। अगर कोई सेट नहीं है, तो हम इस टिप्पणी को तटस्थ मानेंगे।

हमारे मॉडल में अंतिम दो टेबल उन स्थितियों से संबंधित हैं जिन्हें हम ऑर्डर के लिए असाइन करेंगे। status_catalog तालिका में सभी संभावित UNIQUE status_name . की एक सूची है विशेषताएँ जिन्हें हम ऑर्डर पर असाइन कर सकते हैं। order_status तालिका में सभी स्थितियाँ होती हैं जो आदेशों को सौंपी जाती हैं। इस तालिका में प्रत्येक रिकॉर्ड के लिए, हम ऑर्डर और स्थिति से संबंधित विदेशी कुंजी और यह स्थिति निर्दिष्ट किए जाने पर टाइमस्टैम्प संग्रहीत करेंगे।

आप रेस्टोरेंट डिलीवरी डेटा मॉडल के बारे में क्या सोचते हैं?

आज हमने एक डेटा मॉडल पर चर्चा की है जिसका उपयोग रेस्तरां डिलीवरी ऑर्डर को व्यवस्थित, प्रबंधित और स्टोर करने के लिए किया जा सकता है। हम प्रत्येक आदेश की स्थिति और कुछ वित्तीय विवरणों को ट्रैक कर सकते हैं। मेरे पास इस बारे में कुछ विचार हैं कि हम इस मॉडल को और अधिक मजबूत कैसे बना सकते हैं, लेकिन मुझे आपकी राय जानकर खुशी होगी। कृपया इसे टिप्पणी अनुभाग में साझा करें!


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SSH से एक डेटाबेस का बैकअप / निर्यात करें

  2. 911/112:एक आपातकालीन कॉल सेवा डेटा मॉडल

  3. PIVOT, UNPIVOT, और रिवर्स PIVOT स्टेटमेंट को समझना

  4. टी-एसक्यूएल बग, नुकसान, और सर्वोत्तम अभ्यास - धुरी और अनपिवोटिंग

  5. GDI संसाधन रिसाव को संभालना