বাইরের যোগদানের কারণ
যাইহোক, আপনার কি মনে আছে যখন আমরা আমাদের স্প্রেডশীটগুলিকে একত্রিত করেছিলাম এবং আমাদের অফিস পরিষ্কার করার কাজগুলি অদৃশ্য হয়ে গিয়েছিল কারণ এখনও কোনও ক্লিনার ছিল না?
আপনি যদি এই মত একটি প্রশ্ন চালান:
SELECT * FROM task
তারপর আমরা এই ফলাফল পেতে:
আইডি | emploee_id | নাম | শেষ তারিখ |
---|---|---|---|
1 | 1 | ফ্রন্টএন্ডে একটি বাগ ঠিক করুন | 2022-06-01 |
2 | 2 | ব্যাকএন্ডে একটি বাগ ঠিক করুন | 2022-06-15 |
3 | 5 | কফি কিনুন | 2022-07-01 |
4 | 5 | কফি কিনুন | 2022-08-01 |
5 | 5 | কফি কিনবে | 2022-09-01 |
6 | (খালি) | অফিস পরিষ্কার করুন | (খালি) |
7 | 4 | জীবন উপভোগ করুন | (খালি) |
8 | 6 | জীবন উপভোগ করুন | (খালি) |
"ক্লিয়ার অফিস" টাস্কটি অদৃশ্য হয়ে যায় যদি আমরা কর্মীর টেবিলের সাথে কর্মীর টেবিলে কর্মীর_আইডি দ্বারা যোগদান করার চেষ্টা করি।
এই সমস্যা সমাধানের জন্য, JOIN অপারেটরে বিভিন্ন মডিফায়ার যোগ করা হয়েছে যা এই ধরনের অনাথ সারিগুলিকে অন্য টেবিলে জোড়া ছাড়াই সংরক্ষণ করার অনুমতি দেয়।
আমি আপনাকে JOIN অপারেটরের ক্লাসিক ফর্মের কথা মনে করিয়ে দিই:
table 1 JOIN table 2 ON
condition
আমরা SQL সার্ভারকে বলতে পারি যে বাম টেবিলের (টেবিল1) সমস্ত ডেটা যুক্ত করা টেবিলে উপস্থিত রয়েছে তা নিশ্চিত করতে। সঠিক ছকে তাদের জন্য জুড়ি না থাকলেও। এটি করার জন্য, আপনাকে কেবল লিখতে হবে:
table 1 LEFT JOIN table 2 ON condition
আপনি যদি চান যে যোগ করা টেবিলে ডান টেবিল থেকে সমস্ত সারি থাকে , তাহলে আপনাকে লিখতে হবে:
table 1 RIGHT JOIN table 2 ON
condition
আসুন একটি প্রশ্ন লিখি যা সমস্ত কাজ এবং কর্মচারীদের একত্রিত করবে যাতে নির্বাহক ছাড়া কাজগুলি হারিয়ে না যায়। এটি করার জন্য, একটি প্রশ্ন লিখুন:
SELECT * FROM employee e RIGHT JOIN task t ON e.id = t.emploee_id
এবং এই প্রশ্নের ফলাফল:
আইডি | নাম | পেশা | বেতন | বয়স | তারিখ যোগ দিতে | আইডি | emploee_id | নাম |
---|---|---|---|---|---|---|---|---|
1 | ইভানভ ইভান | প্রোগ্রামার | 100000 | 25 | 2012-06-30 | 1 | 1 | ফ্রন্টএন্ডে একটি বাগ ঠিক করুন |
2 | পেট্রোভ পেট্র | প্রোগ্রামার | 80000 | 23 | 2013-08-12 | 2 | 2 | ব্যাকএন্ডে একটি বাগ ঠিক করুন |
4 | রাবিনোভিচ মইশা | পরিচালক | 200000 | 35 | 2015-05-12 | 7 | 4 | জীবন উপভোগ করুন |
5 | কিরিয়েনকো আনাস্তাসিয়া | অফিস ব্যবস্থাপক | 40000 | 25 | 2015-10-10 | 3 | 5 | কফি কিনুন |
5 | কিরিয়েনকো আনাস্তাসিয়া | অফিস ব্যবস্থাপক | 40000 | 25 | 2015-10-10 | 4 | 5 | কফি কিনুন |
5 | কিরিয়েনকো আনাস্তাসিয়া | অফিস ব্যবস্থাপক | 40000 | 25 | 2015-10-10 | 5 | 5 | কফি কিনুন |
6 | ভাস্কা | বিড়াল | 1000 | 3 | 2018-11-11 | 8 | 6 | জীবন উপভোগ করুন |
(খালি) | (খালি) | (খালি) | (খালি) | (খালি) | (খালি) | 6 | (খালি) | অফিস পরিষ্কার করুন |
আমাদের টেবিলে আরেকটি সারি যোগ করা হয়েছে, এবং মজার বিষয় হল, এতে প্রচুর NULL মান রয়েছে। কর্মচারী টেবিল থেকে নেওয়া সমস্ত ডেটা NULL হিসাবে প্রদর্শিত হয়, যেহেতু "ক্লিন অফিস" কাজের জন্য কর্মচারী টেবিল থেকে কোনও নির্বাহক ছিল না।
যোগ দিন প্রকার
মোট 4 ধরনের JOIN আছে। সেগুলি নীচের সারণীতে উপস্থাপন করা হয়েছে:
সংক্ষিপ্ত এন্ট্রি | দীর্ঘ প্রবেশ | ব্যাখ্যা | |
---|---|---|---|
1 | যোগ দিন | ভেতরের যোগ দিতে | শুধুমাত্র রেকর্ড যেগুলি সারণি A এবং B তে রয়েছে |
2 | বাম যোগদান | বাম বাইরে যোগদান | টেবিল A থেকে একটি জোড়া ছাড়া সমস্ত সারি হতে হবে |
3 | ডান যোগদান | ডান বাইরে যোগদান | টেবিল B থেকে একটি জোড়া ছাড়া সমস্ত সারি হতে হবে |
4 | বাইরের যোগদান | সম্পূর্ণ বাইরে যোগদান | টেবিল A এবং B থেকে বেস জোড়ার সমস্ত সারি হতে হবে |
সরলতার জন্য, যদি আমরা টেবিলগুলিকে সেট হিসাবে উপস্থাপন করি, তাহলে JOIN একটি ছবি হিসাবে প্রদর্শিত হতে পারে:

সেট ইন্টারসেকশন মানে হল যে একটি টেবিলের জন্য অন্য টেবিল থেকে একটি সংশ্লিষ্ট রেকর্ড আছে যা এটি উল্লেখ করে।
সাক্ষাৎকার থেকে প্রশ্ন
কখনও কখনও নবীন প্রোগ্রামারদের একটি সাক্ষাত্কারে একটি খুব সাধারণ প্রশ্ন দিয়ে বোমাবাজি করা হয়। আমাদের টেবিল দেওয়া, এটি নিম্নরূপ প্রণয়ন করা যেতে পারে:
"একটি প্রশ্ন লিখুন যা সমস্ত কর্মচারীদের একটি তালিকা প্রদর্শন করবে যাদের জন্য কোন কাজ নেই ।" প্রথমে, আসুন এই প্রশ্নটি একটু রিফ্রেস করার চেষ্টা করি: "একটি প্রশ্ন লিখুন যা কর্মচারী টেবিলের সমস্ত কর্মচারীর একটি তালিকা প্রদর্শন করবে যার জন্য টাস্ক টেবিলে কোন কাজ নেই। " আমাদের এই সেটটি পেতে হবে:
এই সমস্যাটি সমাধান করার অনেক উপায় আছে, কিন্তু আমি সবচেয়ে সহজটি দিয়ে শুরু করব: প্রথমে, আপনি একটি বাম যোগদানের মাধ্যমে আমাদের টেবিলে যোগ দিতে পারেন, এবং তারপরে যেখানে অনুপস্থিত ডেটা NULL দিয়ে প্যাড করা হয়েছিল সেই সমস্ত সারিগুলি বাদ দিতে WHERE ব্যবহার করুন৷
SELECT * FROM employee e LEFT JOIN task t ON e.id = t.emploee_id
WHERE t.id IS NULL
এবং এই প্রশ্নের ফলাফল:
আইডি | নাম | পেশা | বেতন | বয়স | তারিখ যোগ দিতে | আইডি | emploee_id | নাম |
---|---|---|---|---|---|---|---|---|
3 | ইভানভ সের্গেই | পরীক্ষক | 40000 | ত্রিশ | 2014-01-01 | (খালি) | (খালি) | (খালি) |
এই সমাধানের একমাত্র অসুবিধা হল এখানে টেবিলের সারিগুলিতে NULL রয়েছে এবং শর্ত অনুসারে আমাদের কর্মীদের একটি তালিকা প্রদর্শন করতে হবে।
এটি করার জন্য, আপনাকে হয় SELECT এ কর্মচারী টেবিলের প্রয়োজনীয় কলামগুলি তালিকাভুক্ত করতে হবে, অথবা আপনার যদি সেগুলি প্রদর্শন করার প্রয়োজন হয় তবে আপনি নিম্নলিখিত নির্মাণ লিখতে পারেন:
SELECT e.* FROM employee e, task t
সম্পূর্ণ অনুরোধ এই মত দেখাবে:
SELECT e.*
FROM employee e RIGHT JOIN task t ON e.id = t.emploee_id
WHERE t.id IS NULL
এই প্রশ্নের ফলাফল:
আইডি | নাম | পেশা | বেতন | বয়স | তারিখ যোগ দিতে |
---|---|---|---|---|---|
3 | ইভানভ সের্গেই | পরীক্ষক | 40000 | ত্রিশ | 2014-01-01 |
হোমওয়ার্কের জন্য বাকি পদ্ধতিগুলি আপনার হাতে ছেড়ে দেওয়া হয়েছে। আমি আপনাকে তাদের খুঁজে পাওয়ার আনন্দ থেকে বঞ্চিত করতে চাই না।
GO TO FULL VERSION