ধাপ ১: বেতন গ্রেড তৈরি করা
প্রথমে, কোম্পানির জন্য প্রয়োজনীয় বেতন গ্রেড তৈরি করতে হবে। উদাহরণস্বরূপ, যদি আপনার কোম্পানিতে তিনটি বেতন গ্রেড থাকে:
- G1: 30,000 – 45,000
- G2: 45,000 – 60,000
- G3: 60,000 – 75,000
ডেটা এন্ট্রি:
- Salary Grades Table এ ডেটা এন্ট্রি হবে:
| grade_id | grade_name | min_salary | max_salary |
|---|---|---|---|
| 1 | G1 | 30000 | 45000 |
| 2 | G2 | 45000 | 60000 |
| 3 | G3 | 60000 | 75000 |
ধাপ ২: পদের তথ্য সংযুক্ত করা
এখন কোম্পানির পদের তথ্য সংযুক্ত করতে হবে। ধরুন, একটি পদ “Software Engineer”।
ডেটা এন্ট্রি:
- Positions Table এ ডেটা এন্ট্রি হবে:
| position_id | position_title |
|---|---|
| P01 | Software Engineer |
ধাপ ৩: কর্মচারীর মৌলিক তথ্য এন্ট্রি
এখন কর্মচারীর মৌলিক তথ্য সংগ্রহ করতে হবে। ধরুন কর্মচারীর নাম “রাহুল”, কর্মচারী আইডি “E001”, জন্ম তারিখ “1990-01-01”, যোগদানের তারিখ “2023-10-01”, বিভাগ ID “D01”, এবং পদের ID “P01″।
ডেটা এন্ট্রি:
- Employees Table এ ডেটা এন্ট্রি হবে:
| employee_id | name | date_of_birth | joining_date | department_id | position_id |
|---|---|---|---|---|---|
| E001 | রাহুল | 1990-01-01 | 2023-10-01 | D01 | P01 |
ধাপ ৪: কর্মচারীর বেতন কাঠামো তৈরি করা
এখন রাহুলের জন্য মৌলিক বেতন নির্ধারণ করতে হবে। ধরুন, তার বেতন গ্রেড G2।
ডেটা এন্ট্রি:
- Salary Structure Table এ ডেটা এন্ট্রি হবে:
| structure_id | employee_id | base_salary | total_salary |
|---|---|---|---|
| 1 | E001 | 50000 | 60000 |
ধাপ ৫: বেতন উপাদান যোগ করা
এখন রাহুলের বেতন উপাদান যোগ করুন। যেমন: মৌলিক বেতন, হাউজ রেন্ট অ্যালাউন্স, মেডিক্যাল অ্যালাউন্স ইত্যাদি। ধরুন, হাউজ রেন্ট অ্যালাউন্স 5,000 টাকা, মেডিক্যাল অ্যালাউন্স 2,000 টাকা।
ডেটা এন্ট্রি:
- Salary Component Table এ ডেটা এন্ট্রি হবে:
| component_id | structure_id | component_name | amount |
|---|---|---|---|
| 1 | 1 | Basic Salary | 50000 |
| 2 | 1 | House Rent Allowance | 5000 |
| 3 | 1 | Medical Allowance | 2000 |
ধাপ ৬: কাটা অর্থ যুক্ত করা
এখন রাহুলের জন্য কিছু কাটা অর্থ যুক্ত করতে হবে। যেমন, প্রভিডেন্ট ফান্ড 2,000 টাকা এবং পেশাদার কর 500 টাকা।
ডেটা এন্ট্রি:
- Salary Deductions Table (যদি থাকে) এ ডেটা এন্ট্রি হবে:
| deduction_id | structure_id | deduction_name | amount |
|---|---|---|---|
| 1 | 1 | Provident Fund | 2000 |
| 2 | 1 | Professional Tax | 500 |
ধাপ ৭: চূড়ান্ত বেতন হিসাব করা
এখন রাহুলের Final Salary হিসাব করুন:
- Final Salary = Base Salary + Total Allowances – Total Deductions
- Final Salary = 50,000 + 7,000 – 2,500 = 54,500 টাকা (যদি অন্যান্য অ্যালাউন্স যোগ করে হিসাব করা হয়)
সারসংক্ষেপ
- Salary Grades Table এ গ্রেডের তথ্য।
- Positions Table এ পদের তথ্য।
- Employees Table এ কর্মচারীর মৌলিক তথ্য।
- Salary Structure Table এ কর্মচারীর বেতন কাঠামো।
- Salary Component Table এ বিভিন্ন বেতন উপাদান।
- Salary Deductions Table এ কাটা অর্থ।
এইভাবে, সঠিক ক্রমে তথ্য এন্ট্রি করার মাধ্যমে সমস্ত টেবিলে সঠিকভাবে ডেটা ইন্সার্ট হবে এবং প্রক্রিয়াটি সম্পন্ন হবে।
Salary Component Table এবং Salary Deductions Table এ ডেটা অ্যাড বা আপডেট করার সময় Salary Structure Table এর total_salary অটোমেটিক আপডেট করার ব্যবস্থা করা উচিত। এটির জন্য নিম্নলিখিত পদ্ধতি অনুসরণ করতে পারেন:
১. ডাটাবেস ট্রিগার ব্যবহার করা
ডাটাবেসে ট্রিগার তৈরি করে আপনি যখন Salary Component বা Salary Deductions টেবিলের ডেটা অ্যাড বা আপডেট করবেন, তখন স্বয়ংক্রিয়ভাবে Salary Structure Table আপডেট করতে পারবেন। উদাহরণস্বরূপ:
CREATE TRIGGER update_total_salary
AFTER INSERT OR UPDATE ON Salary_Component
FOR EACH ROW
BEGIN
UPDATE Salary_Structure
SET total_salary = (SELECT SUM(amount) FROM Salary_Component WHERE structure_id = NEW.structure_id) -
(SELECT SUM(amount) FROM Salary_Deductions WHERE structure_id = NEW.structure_id)
WHERE structure_id = NEW.structure_id;
END;
CREATE TRIGGER update_total_salary_deductions
AFTER INSERT OR UPDATE ON Salary_Deductions
FOR EACH ROW
BEGIN
UPDATE Salary_Structure
SET total_salary = (SELECT SUM(amount) FROM Salary_Component WHERE structure_id = NEW.structure_id) -
(SELECT SUM(amount) FROM Salary_Deductions WHERE structure_id = NEW.structure_id)
WHERE structure_id = NEW.structure_id;
END;
২. অ্যাপ্লিকেশন স্তরে অটোমেশন
আপনার অ্যাপ্লিকেশনে (যেমন Django, Node.js ইত্যাদি) সেভ বা আপডেট করার লজিক লিখতে হবে, যাতে Salary Component এবং Salary Deductions টেবিলে ডেটা অ্যাড বা আপডেট করার পরে Salary Structure Table এর total_salary আপডেট হয়। উদাহরণস্বরূপ:
# Django Example
def update_salary_structure(structure_id):
total_allowances = SalaryComponent.objects.filter(structure_id=structure_id).aggregate(Sum('amount'))['amount__sum'] or 0
total_deductions = SalaryDeduction.objects.filter(structure_id=structure_id).aggregate(Sum('amount'))['amount__sum'] or 0
total_salary = base_salary + total_allowances - total_deductions
SalaryStructure.objects.filter(structure_id=structure_id).update(total_salary=total_salary)
# Call this function after adding/updating a Salary Component or Deduction
৩. ম্যানুয়াল আপডেট
যদি অটোমেটিক আপডেটের কোনো ব্যবস্থা না থাকে, তবে আপনাকে ম্যানুয়ালি Salary Structure Table আপডেট করতে হবে। তবে এটি সময়সাপেক্ষ এবং মানুষের ভুলের সম্ভাবনা বাড়ায়।
সারসংক্ষেপ
- অটোমেশন (ডাটাবেস ট্রিগার বা অ্যাপ্লিকেশন স্তরে লজিক) ব্যবহারে সুবিধা হবে, কারণ এতে আপডেট করা সহজ এবং দ্রুত হবে।
- ম্যানুয়াল আপডেট করা হলেও এটি সতর্কতার সাথে করতে হবে, কিন্তু এটি অটোমেশনের চেয়ে ঝুঁকিপূর্ণ।
অতএব, অটোমেটিক আপডেটের ব্যবস্থা করা সবচেয়ে ভালো পন্থা।