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

डेटाबेस में कर्मचारियों की अनुसूचियों को कैसे स्टोर करें

स्तर:शुरुआती

इतने सारे संगठन कर्मचारी शेड्यूल को संग्रहीत करने की आम समस्या का सामना करते हैं। कोई फर्क नहीं पड़ता कि कौन सी संस्था:एक कंपनी, एक विश्वविद्यालय या बस एक व्यक्ति, कई संस्थाओं को कार्यक्रम देखने के लिए एक आवेदन की आवश्यकता होती है। इसलिए, मैं एक डेटाबेस मॉडल के साथ आने की कोशिश करूंगा और फिर, भविष्य के लेख में, हम एक डेटाबेस में कर्मचारियों के शेड्यूल को स्टोर करने के लिए एक सरल एप्लिकेशन के बारे में बात करेंगे।

वर्तमान में डिजाइन इस प्रकार दिखता है:

मॉडल बहुत सीधा है।

टिप - प्राकृतिक और सरोगेट प्रमुख रणनीतियां

  1. सरोगेट प्राथमिक कुंजी का उपयोग करें जब भी प्राकृतिक कुंजी में मान संभवतः बदल सकते हैं या जब कोई प्राकृतिक कुंजी बहुत जटिल हो।
  2. यदि एक प्राकृतिक उम्मीदवार कुंजी में कम संख्या में कॉलम होते हैं (आदर्श रूप से केवल एक) और इसके मान नहीं बदलते हैं - इसे प्राकृतिक प्राथमिक कुंजी के रूप में उपयोग करें

और जानें प्राकृतिक और सरोगेट प्राथमिक कुंजी के बारे में।

employee तालिका में प्रत्येक कर्मचारी का वर्णन करने वाली बुनियादी विशेषताएं हैं, उदाहरण के लिए:नाम, उपनाम, पता और फोन नंबर। नाम और उपनाम प्रत्येक रिकॉर्ड की विशिष्ट रूप से पहचान नहीं करते हैं (एक ही नाम और उपनाम वाले एक से अधिक व्यक्ति हो सकते हैं), इसलिए एक नया कॉलम पेश किया गया था (id ), जिसे सरोगेट कुंजी . कहा जाता है ।

schedule तालिका में वे दिन और घंटे होते हैं जब प्रत्येक कर्मचारी काम पर होता है। work_date कॉलम उस दिन को निर्दिष्ट करता है जब प्रत्येक कर्मचारी काम कर रहा था। start_work_hour और end_work_hour कॉलम उस दिन के काम के घंटों की पहचान करते हैं।

आइए मान लें कि हमारे पास पीटर नामक एक कर्मचारी है। वह 4 फरवरी को काम पर था और वह शेड्यूल में अपने प्रारंभ और समाप्ति समय को चिह्नित करता है।

schedule तालिका इस तरह दिखती है:


id कर्मचारी_आईडी कार्य_तिथि start_work_hour end_work_hour is_holiday is_weekend
1 1 2015-02-04 10 16 0 0


इस तरह की प्रणाली का निर्माण करते समय हम यह जानना चाह सकते हैं कि किसने सबसे अधिक रातें काम कीं या किसने सबसे अधिक सप्ताहांत/छुट्टियों में काम किया। ऐसी जानकारी वाली रिपोर्ट जेनरेट करने के लिए, कॉलम is_holiday और is_weekend पेश किए गए थे।

इस दृष्टिकोण का उपयोग करने के लिए आपको छुट्टियों के लिए एक अलग तालिका की आवश्यकता होगी जिसमें कंपनी के लिए छुट्टियों की तिथियां हों। जब कोई कर्मचारी अपने कार्य समय में प्रवेश करता है, तो कॉलम is_holiday और is_weekend ट्रिगर का उपयोग करके अद्यतन किया जा सकता है। तारीख और समय डालने के बाद, ट्रिगर यह जांच करेगा कि तारीख छुट्टी है या सप्ताहांत और फ़ील्ड में सही मान डालें।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Google BigQuery को IRI Voracity सॉफ़्टवेयर से कनेक्ट करना

  2. ज़ोंबी परफ़ॉर्मेंस काउंटर जो कभी नहीं मरते!

  3. ऑप्टिमाइज़ेशन थ्रेशोल्ड - डेटा को समूहीकृत करना और एकत्र करना, भाग 1

  4. अधिक ऑनलाइन संचालन अभी उपलब्ध हैं - या जल्द ही

  5. बड़े डिलीट ऑपरेशंस को टुकड़ों में तोड़ें