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

किराए पर लें या किराए पर लें:भर्ती प्रक्रिया के लिए एक डेटा मॉडल

कोई फर्क नहीं पड़ता कि आप समीकरण के किस पक्ष में हैं, कभी-कभी किसी विशिष्ट कार्य के लिए योग्य व्यक्ति को खोजना कठिन होता है। इस पोस्ट में, हम भर्ती प्रक्रिया के दौरान भर्ती करने वालों और मानव संसाधन विभागों को संगठित रहने में मदद करने के लिए एक डेटा मॉडल को देखते हैं।

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

भर्ती अपने आप में बहुत जटिल है, इसलिए हम प्रक्रिया के सभी पहलुओं को कवर करने के लिए एक काफी व्यापक डेटा मॉडल पर चर्चा करेंगे। अपनी कुर्सी पर वापस बैठें और आज के लेख का आनंद लें!

भर्ती प्रक्रिया कैसे काम करती है

भर्ती प्रक्रिया के अधिकांश भाग सामान्य ज्ञान हैं, लेकिन डेटा मॉडल पर आगे बढ़ने से पहले हम ठीक से चर्चा करेंगे कि यह कैसे काम करता है।

  1. आवश्यकता का पता लगाना

    भर्ती प्रक्रिया में यह एक परम आवश्यक है; यदि प्रबंधन को नए कर्मचारी को नियुक्त करने की आवश्यकता के बारे में जानकारी नहीं है तो कोई प्रक्रिया नहीं होगी। यह आवश्यकता एक नई कंपनी शुरू करने, मौजूदा कंपनी में वृद्धि या किसी मौजूदा कर्मचारी के प्रस्थान का परिणाम हो सकती है।

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

  2. स्थिति और उसके आवश्यक कौशल को रेखांकित करना

    इस कदम का अंदाजा लगाने के लिए, वास्तव में अच्छी तरह से लिखे गए नौकरी के विवरण के बारे में सोचें। इसमें शामिल हैं:

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

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

  3. यह परिभाषित करना कि प्रक्रिया का प्रबंधन कौन करेगा और प्रत्येक कार्य कब होना चाहिए

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

    यदि कोई मानव संसाधन विभाग नहीं है, तो हम उम्मीद कर सकते हैं कि प्रबंधन कर्मी प्रक्रिया के प्रभारी होंगे। छोटी और मध्यम आकार की कंपनियों में, इसकी न केवल आवश्यकता है, बल्कि वांछित है।

  4. नौकरी पोस्ट करना

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

  5. उम्मीदवारों का चयन, परीक्षण और साक्षात्कार

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

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

    साक्षात्कार और परीक्षण प्रक्रिया कंपनी के आकार और संगठन के अनुसार अलग-अलग होगी। मानव संसाधन विभागों वाली बड़ी कंपनियों में, आवेदकों के नौकरी कौशल की जांच के लिए परीक्षणों का एक सेट होने की संभावना है। अन्य परीक्षण आवेदक-नौकरी मैच, आवेदक-कंपनी मैच, या यहां तक ​​​​कि आवेदक की विवेक को निर्धारित करने के लिए मनोवैज्ञानिक और व्यक्तित्व लक्षणों को माप सकते हैं।

    इन परीक्षणों को आम तौर पर कई चरणों में विभाजित किया जाएगा, और प्रत्येक चरण में आवेदकों की संख्या कम हो जाएगी।

  6. अंतिम साक्षात्कार

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

    • क्या छोटे, मध्यम और बड़े व्यवसायों की भर्ती प्रक्रिया में अंतर है? हम उन्हें अपने मॉडल में कैसे हल करेंगे?

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

      इस मॉडल में, मैं सभी परीक्षणों और साक्षात्कारों को एक समान मानूंगा। हम प्रत्येक आवेदक के उत्तरों को संग्रहीत करेंगे, उन्हें प्रासंगिक प्रश्न से जोड़ेंगे, और प्रक्रिया के प्रत्येक चरण के लिए आवेदक के स्कोर को संग्रहीत करेंगे।

    • इस डेटा मॉडल का उपयोग कौन कर सकता है?

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

डेटा मॉडल




डेटा मॉडल में पांच मुख्य विषय क्षेत्र होते हैं:

  • Jobs
  • Applicants, Recruiters and Documents
  • Applications
  • Test details
  • Application tests

मैं प्रत्येक विषय क्षेत्र का अलग से वर्णन करूंगा, उसी क्रम में वे सूचीबद्ध हैं।

अनुभाग 1:नौकरियां

Jobs अनुभाग हमारे द्वारा पोस्ट किए गए सभी पदों के लिए सभी विवरण संग्रहीत करेगा। दो शब्दकोश तालिकाएं, company तालिका और job_type तालिका, प्रारंभिक सेटअप का हिस्सा हैं। शेष दो टेबल, job और posted_on , नौकरी पोस्टिंग से संबंधित "वास्तविक" डेटा शामिल करें।

job_type शब्दकोश में विभिन्न और अद्वितीय कार्य प्रकारों की एक सूची है। हम “वरिष्ठ डेटाबेस व्यवस्थापक” . जैसे मूल्यों की अपेक्षा कर सकते हैं या “आईटी पत्रकार” type_name . में स्टोर करने के लिए गुण। type_description विशेषता नौकरी का अधिक विस्तृत विवरण संग्रहीत कर सकती है।

company डिक्शनरी में उन सभी कंपनियों की सूची है, जिनके साथ हम काम करते हैं। यदि हम केवल अपनी कंपनी के लिए कर्मचारियों को नियुक्त करते हैं, तो इस शब्दकोश में केवल हमारी कंपनी का नाम होगा। अगर हम एक भर्ती एजेंसी हैं, तो यह हर उस कंपनी के नाम रखेगी जिसने हमें काम पर रखा है।

हमारे द्वारा पोस्ट की गई प्रत्येक नौकरी की स्थिति की एक सूची "नौकरी" तालिका में संग्रहीत की जाती है। इस तालिका में विशेषताएँ हैं:

  • code - हमारी आंतरिक UNIQUE ID किसी कार्य को दर्शाने के लिए प्रयोग की जाती है।
  • job_type_id - संबंधित नौकरी के प्रकार का संदर्भ देता है।
  • posted_date - वह तिथि जब यह नौकरी की स्थिति पोस्ट की गई थी।
  • start_date - उस कार्य के लिए अपेक्षित प्रारंभ तिथि (पहला कार्य दिवस)।
  • employees_needed - इस भर्ती प्रक्रिया के दौरान हम जितने कर्मचारियों को नियुक्त करना चाहते हैं। अधिकतर इसका मान "1" होगा, लेकिन कुछ मामलों में - उदा. एक नई कंपनी शुरू करते समय या एक नया विभाग स्थापित करते समय - हम बड़े मूल्यों की उम्मीद कर सकते हैं।
  • description - उस स्थिति का विस्तृत विवरण। यह वह जगह है जहां हम सभी आवश्यक, पसंदीदा और वांछित नौकरी कौशल सूचीबद्ध करेंगे।
  • company_id - उस कंपनी की आईडी का संदर्भ देता है जिसने हमें काम पर रखा है। यदि हम एक भर्ती एजेंसी हैं, तो यह company टेबल। अन्यथा, यह हमारी अपनी कंपनी की आईडी होगी।
  • date_process_started - भर्ती प्रक्रिया शुरू होने की तिथि। यदि हमें इस कार्य के संबंध में भविष्य के चरणों और कार्यों को परिभाषित करने की आवश्यकता है तो यह NULL हो सकता है।

इस विषय क्षेत्र में अंतिम तालिका posted_on टेबल। प्रत्येक job_id . के लिए , हम एक link स्टोर करेंगे नौकरी की पोस्ट और संबंधित description . के लिए . हम इस डेटा का उपयोग यह जानने के लिए कर सकते हैं कि आवेदकों को हमारे जॉब पोस्ट कहां मिलते हैं।

अनुभाग 2:आवेदक, भर्तीकर्ता और दस्तावेज़

इस विषय क्षेत्र में भर्ती करने वालों, आवेदकों और उनके संबंधित दस्तावेजों के बारे में जानकारी संग्रहीत करने के लिए आवश्यक सभी तालिकाएँ हैं।

applicant तालिका उन सभी आवेदकों को सूचीबद्ध करती है जिनके साथ हमने कभी संपर्क किया है। प्रत्येक आवेदक को हमारे सिस्टम में "कोड" के साथ विशिष्ट रूप से परिभाषित किया गया है। इसके अलावा, हम प्रत्येक आवेदक का पहला और अंतिम नाम, phone . स्टोर करेंगे नंबर, email पता, और उनका summary . इस तालिका को विशिष्ट आवश्यकताओं के लिए समायोजित किया जा सकता है, उदा। अतिरिक्त फ़ोन नंबर, ईमेल या भौतिक पते जोड़ना।

हम उपलब्ध दस्तावेजों के साथ आवेदकों से संबंधित होंगे। document टेबल। प्रत्येक दस्तावेज़ के लिए, हम उसका नाम सिस्टम, उसके स्थान और नवीनतम अपडेट के समय में संग्रहीत करेंगे।

हम related_document टेबल। इसमें केवल दो विदेशी कुंजियाँ होती हैं, जो document_id . बनाती हैं - applicant_id अद्वितीय जोड़ी।

recruiter तालिका उन कर्मचारियों को सूचीबद्ध करती है जिन्हें नौकरी के लिए आवेदन सौंपा जा सकता है या जो आवेदक से संबंधित नोट्स दर्ज करते हैं। प्रत्येक भर्तीकर्ता को उसके या उसके code . द्वारा विशिष्ट रूप से परिभाषित किया जाता है . हम केवल बुनियादी विवरण जैसे first_name . संग्रहित करेंगे , last_name और भर्ती करने वाले का summary

इस विषय क्षेत्र में अंतिम तालिका notes टेबल। यह वह जगह है जहां हम एक आवेदक से संबंधित सभी नोटों को संग्रहीत करेंगे। हम “आवेदक से मीटिंग छूट गई” . जैसे नोट्स स्टोर कर सकते हैं या “आवेदक ने पहले साक्षात्कार में बहुत अच्छा किया” . प्रत्येक नोट के लिए, हम उस भर्तीकर्ता की आईडी, जिसने वह नोट बनाया है, संबंधित आवेदक की आईडी, note_text संग्रहीत करेंगे , और टाइमस्टैम्प जब नोट बनाया गया था।

अनुभाग 3:परीक्षण विवरण

Test details विषय क्षेत्र में भर्ती प्रक्रियाओं और इन प्रक्रियाओं के दौरान उपयोग किए जाने वाले परीक्षणों को परिभाषित करने के लिए उपयोग की जाने वाली तालिकाएँ हैं। हम आम तौर पर समान कार्य प्रकार के लिए समान चयन प्रक्रिया का उपयोग करेंगे:परिवर्तन केवल तभी किए जाते हैं जब वे व्यावसायिक परिस्थितियों के लिए आवश्यक होते हैं। हम प्रत्येक प्रकार के कार्य के लिए कुछ भिन्न प्रक्रियाओं का उपयोग कर सकते हैं, और हम निश्चित रूप से विभिन्न प्रकार के कार्य के लिए समान प्रक्रिया का उपयोग करेंगे।

process तालिका एक साधारण शब्दकोश है जिसमें केवल एक अद्वितीय process_name है गुण। यह उन सभी भर्ती प्रक्रियाओं को सूचीबद्ध करता है जिनका हमने कभी उपयोग किया है और वर्तमान में उपयोग कर रहे हैं।

हम विभिन्न प्रकार के कार्य के साथ प्रक्रियाओं को जोड़ेंगे। हम इन संबंधों को process_available टेबल। इसकी एकमात्र विशेषता UNIQUE जोड़ी है job_type_id - process_id . जब नौकरी के प्रकार के लिए कई प्रक्रियाएं उपलब्ध होती हैं, तो यह भर्तीकर्ता को किसी एक को चुनने की अनुमति देता है।

test_in_process तालिका का उपयोग उस प्रक्रिया के दौरान परीक्षणों के क्रम को परिभाषित करने के लिए किया जाता है। इस तालिका में विशेषताएँ हैं:

  • process_id और test_id - संबंधित प्रक्रिया और परीक्षण का संदर्भ देता है।
  • test_order - उस परीक्षण की क्रम संख्या या प्रक्रिया में कदम। साथ में process_id , यह तालिका की UNIQUE कुंजी बनाता है। प्रक्रिया के दौरान हमारे पास एक समय में केवल एक ही चरण हो सकता है।

test तालिका वर्तमान में और भर्ती प्रक्रिया में पहले उपयोग किए गए सभी परीक्षणों को सूचीबद्ध करती है। हम सीवी समीक्षाओं और साक्षात्कारों को भी परीक्षण के रूप में मानेंगे। हालांकि उन्हें परिभाषित प्रश्नों और उत्तरों की आवश्यकता नहीं है, वे एक मूल्यांकन का हिस्सा हैं। प्रत्येक परीक्षण के लिए, हम संग्रहित करेंगे:

  • test_name - प्रत्येक परीक्षण के लिए एक अद्वितीय पदनाम।
  • test_type_id - संदर्भ test_type शब्दकोश।
  • date_created - वह तारीख जब हमने अपने सिस्टम में यह परीक्षण बनाया था।
  • max_score - इस परीक्षा के लिए प्राप्त होने वाला अधिकतम अंक। यह मान इस परीक्षा के सभी सही उत्तरों या उच्चतम ग्रेड का योग है जो भर्तीकर्ता सीवी या साक्षात्कार के लिए दे सकते हैं।
  • max_duration - आवेदक को कितनी देर (मिनटों में) परीक्षा पूरी करनी है।
  • test_link - परीक्षण स्थान के लिए एक लिंक शामिल है। जब हम इस प्रक्रिया में किसी परीक्षण का उपयोग नहीं करते हैं तो यह मान NULL हो सकता है।
  • is_active - यह दर्शाता है कि क्या हम वर्तमान में इस परीक्षण का उपयोग करते हैं।

हम पहले ही test_type शब्दकोश। इसमें प्रारूप के अनुसार सभी अद्वितीय परीक्षण नाम शामिल हैं, उदा। “सीवी समीक्षा” , “ऑनलाइन कौशल परीक्षण” , "पेपर स्किल टेस्ट" और “साक्षात्कार”

इस मॉडल में परीक्षण प्रश्नों और उत्तरों को संग्रहीत करने के लिए आवश्यक संरचना शामिल नहीं है। बल्कि, यह उन स्थानों के लिए एक लिंक संग्रहीत करता है जिनमें यह जानकारी होती है। Applications . में एक ही डिज़ाइन का उपयोग किया जाएगा विषय क्षेत्र।

अनुभाग 4:अनुप्रयोग

Applications इस डेटा मॉडल में विषय क्षेत्र शायद सबसे महत्वपूर्ण है। अन्य सभी विषय क्षेत्रों में अब तक वर्णित अनुप्रयोगों का उल्लेख किया गया है। यह असली चीजों को स्टोर करता है।

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

समय के साथ आवेदनों की स्थिति बदलेगी। सभी एप्लिकेशन स्थितियों की एक सूची application_status शब्दकोश। केवल विशेषता status_name . है और यह केवल UNIQUE मान रख सकता है। अपेक्षित मानों में शामिल हैं:"लागू" , "CV की समीक्षा की गई" , "परीक्षण के लिए चुना गया" , "CV समीक्षा के बाद अस्वीकृत" , "परीक्षा उत्तीर्ण की" , "एक साक्षात्कार के लिए आमंत्रित" और "आवेदक द्वारा समाप्त"

हम सभी एप्लिकेशन स्थितियों को application_status_history टेबल। इस तालिका में application तालिका और application_status शब्दकोश। हम सटीक status_time . भी स्टोर करेंगे जब यह स्थिति आवेदन को सौंपी गई थी। application_id - status_time जोड़ी इस तालिका की अद्वितीय कुंजी बनाती है।

ज्यादातर मामलों में, एक आवेदक एक आवेदन के साथ केवल एक ही पद के लिए आवेदन करेगा। यह संभव है कि एक आवेदक एक से अधिक पदों के लिए आवेदन करेगा और हम चयन प्रक्रिया के दौरान उनके लिए सबसे उपयुक्त भूमिका का चयन करेंगे। applied_for तालिका में, हम UNIQUE जोड़ी application_id संग्रहित करेंगे - job_id . हम यह भी रिकॉर्ड करेंगे कि उस आवेदन से संबंधित आवेदक selected . था या नहीं उस पद के लिए। हम उम्मीद कर सकते हैं कि सभी selected मान “गलत” . पर सेट हो जाएंगे चयन प्रक्रिया की शुरुआत में और हम प्रत्येक कार्य स्थिति के लिए केवल एक को “True” में अपडेट करेंगे ।

अनुभाग 5:आवेदन परीक्षण

हमारे मॉडल में अंतिम विषय क्षेत्र का उपयोग चयन प्रक्रिया के दौरान लिए गए प्रत्येक परीक्षण के परिणामों को संग्रहीत करने के लिए किया जाएगा। इस विषय क्षेत्र में उपयोग की जाने वाली दो तालिकाएं अन्य विषय क्षेत्रों की प्रतियां हैं:application और recruiter . उनका उपयोग यहां मॉडल को सरल बनाने के लिए किया जाता है।

प्रत्येक परीक्षण से संबंधित सभी विवरण test_taken टेबल। इस तालिका में प्रक्रिया के अन्य सभी चरण भी शामिल हैं जिन्हें सीवी समीक्षा की तरह वर्गीकृत किया जा सकता है। इस तालिका में विशेषताएँ हैं:

  • application_id - संदर्भ application टेबल। यह उस परीक्षार्थी के साथ एक परीक्षण से संबंधित है जिसने वह परीक्षा दी थी।
  • test_id - संदर्भ test सूची हम test_in_process यहाँ तालिका, जो हमें ली गई परीक्षा के बारे में अधिक जानकारी प्रदान करेगी। मैंने ऐसा नहीं करने का फैसला किया क्योंकि यह संरचना हमें अधिक लचीलापन प्रदान करती है। (उदाहरण के लिए, यदि हम आवेदकों को दो बार या सामान्य समय से बाहर परीक्षा देने की अनुमति देना चाहते हैं)।
  • time_created - वास्तविक समय में हमने इस परीक्षण को अपने सिस्टम में सम्मिलित किया था।
  • expected_test_start_time और expected_test_end_time - प्रारंभ और समाप्ति समय, जैसा कि आवेदक के साथ चर्चा की गई है। यदि आवेदक या भर्तीकर्ता को परीक्षा स्थगित करने की आवश्यकता हो तो हम इन मूल्यों को बदल सकते हैं।
  • test_start_time और test_end_time - परीक्षण के लिए वास्तविक प्रारंभ और समाप्ति समय। परीक्षण बनाए जाने पर इनमें NULL मान होंगे; जब आवेदक इस परीक्षण को शुरू करेगा और समाप्त करेगा, तो मूल्यों को अपडेट किया जाएगा।
  • test_status_id - संदर्भ test_status शब्दकोश।
  • test_link - आवेदक के उत्तरों के साथ परीक्षा के लिंक। आवेदक द्वारा परीक्षा सबमिट करने पर इसे अपडेट कर दिया जाएगा।
  • score - उस परीक्षा में आवेदक का स्कोर। यह या तो एक भर्तीकर्ता द्वारा मैन्युअल रूप से निर्धारित किया जाता है (उदाहरण के लिए सीवी समीक्षा के लिए) या स्वचालित रूप से (सभी परीक्षण आइटम स्कोर का योग)। यह उन परीक्षणों के लिए NULL मान भी रख सकता है जो किसी पूर्वनिर्धारित पैमाने पर स्कोर या ग्रेड नहीं किए गए हैं। साथ ही, एक परीक्षण जो शेड्यूल किया गया है लेकिन अभी तक पूरा नहीं हुआ है, उसका NULL मान हो सकता है।
  • max_score - परीक्षण का अधिकतम प्राप्य स्कोर। यह test . में स्टोर किए गए मान के समान है ।"max_score गुण। मैं उस मान को बनाए रखना चाहता हूं क्योंकि भर्तीकर्ता दिए जाने के दौरान परीक्षण को संशोधित कर सकता है और इसलिए प्राप्त किए जा सकने वाले अधिकतम स्कोर को बदल सकता है।
  • notes - उस विशिष्ट परीक्षा के संबंध में भर्तीकर्ताओं द्वारा दर्ज किया गया कोई भी अतिरिक्त नोट या टिप्पणी।

test_id . का संयोजन - application_id - expected_test_start_time विशेषताएँ इस तालिका की UNIQUE कुंजी बनाती हैं। एक नया परीक्षण सत्र जोड़ने से पहले, हमें अभी भी संबंधित आवेदक और सभी संबंधित भर्तीकर्ताओं के लिए अतिव्यापी परीक्षण अंतरालों की जांच करनी चाहिए।

test_status शब्दकोश में हर UNIQUE status_name . की एक सूची है जिसे एक परीक्षण के लिए सौंपा जा सकता है। कुछ अपेक्षित मानों में शामिल हैं:"शुरू नहीं हुआ" , "प्रगति पर" , "सफलतापूर्वक पूर्ण हुआ" , "असफल पूर्ण" , "स्थगित" , "रद्द किया गया" और "आवेदक रद्द कर दिया गया"

हमारे मॉडल में अंतिम तालिका recruiter_graded तालिका, जो सभी ग्रेड भर्तीकर्ताओं को संग्रहीत करती है जो प्रत्येक परीक्षा को ग्रेडिंग करते समय देते हैं। इसलिए, हम recruiter और test_taken टेबल। हम score भी स्टोर करेंगे साथ ही किसी भी notes . को हासिल किया . यह जानकारी बहुत महत्वपूर्ण है, खासकर जब हम मैन्युअल रूप से परीक्षण ग्रेडिंग कर रहे हैं (यानी सीवी समीक्षा और साक्षात्कार के लिए)।

आज हमने एक डेटा मॉडल पर चर्चा की है जो चयन और भर्ती प्रक्रिया में लगभग किसी भी स्थिति को कवर कर सकता है - जिसमें असामान्य अपवाद भी शामिल हैं।

हम में से अधिकांश के पास इस विषय में कुछ विशेषज्ञता है। कृपया अपना अनुभव साझा करें जब आप भर्तीकर्ता की भूमिका में थे या डेस्क के दूसरी तरफ थे। क्या यह मॉडल उन स्थितियों को कवर करता है जिनका आपने सामना किया? यदि नहीं, तो आप क्या परिवर्तन प्रस्तावित करेंगे?


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. समस्या निवारण हमेशा चालू - कभी-कभी इसमें कई तरह की आंखें होती हैं

  2. डेटाबेस रीऑर्ग्स - वे क्यों मायने रखते हैं?

  3. निष्पादन योजना ऑपरेटर समय को समझना

  4. वास्तविक स्वचालित प्रक्रिया के लिए SQL ट्यूनिंग के लिए AI का उपयोग कैसे करें

  5. उदाहरणों में बैकअप की निगरानी करना