আমি মাইএসকিউএলে একটি সম্পূর্ণ আউটার জয়েন করতে চাই। এটা কি সম্ভব? মাইএসকিউএল দ্বারা সমর্থিত একটি পূর্ণ আউটার যোগদান কি?
আমি মাইএসকিউএলে একটি সম্পূর্ণ আউটার জয়েন করতে চাই। এটা কি সম্ভব? মাইএসকিউএল দ্বারা সমর্থিত একটি পূর্ণ আউটার যোগদান কি?
উত্তর:
আপনার মাইএসকিউএলে সম্পূর্ণ যোগদান নেই, তবে আপনি অবশ্যই সেগুলি অনুকরণ করতে পারবেন ।
একটি কোডের জন্য SAMPLE এই এই প্রশ্ন থেকে প্রতিলিপি আপনার কাছে রয়েছে:
দুটি সারণী টি 1, টি 2 সহ:
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
উপরের ক্যোয়ারীটি বিশেষ ক্ষেত্রে কাজ করে যেখানে পুরো আউট জয়েন অপারেশনটিতে কোনও সদৃশ সারি তৈরি হয় না। উপরের UNION
ক্যোয়ারী কোয়েরি প্যাটার্ন দ্বারা প্রবর্তিত সদৃশ সারিগুলি সরানোর জন্য সেট অপারেটরের উপর নির্ভর করে । আমরা দ্বিতীয় ক্যোয়ারির জন্য একটি অ্যান্টি-জয়েন প্যাটার্ন ব্যবহার করে সদৃশ সারিগুলির পরিচয় এড়াতে পারি এবং তারপরে দুটি সেট একত্রিত করতে একটি ইউনিয়ন সমস্ত সেট অপারেটর ব্যবহার করি। আরও সাধারণ ক্ষেত্রে, যেখানে পুরো আউটয়ার জয়েন সদৃশ সারিগুলি ফিরিয়ে দেয়, আমরা এটি করতে পারি:
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION ALL
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
WHERE t1.id IS NULL
(SELECT ... FROM tbl1 LEFT JOIN tbl2 ...) UNION ALL (SELECT ... FROM tbl1 RIGHT JOIN tbl2 ... WHERE tbl1.col IS NULL)
t1
এবং t2
, এই উত্তরের ক্যোয়ারী এমন একটি রেজাল্ট দেয় যা সম্পূর্ণ আউট জয়েনকে এমুলেট করে। তবে আরও সাধারণ ক্ষেত্রে, উদাহরণস্বরূপ, নির্বাচিত তালিকায় প্রত্যাবর্তিত সারিগুলি অনন্য করে তুলতে পর্যাপ্ত কলাম / এক্সপ্রেশন থাকে না, তবে এই ক্যোয়ারী বিন্যাসটি এটি দ্বারা উত্পাদিত সেটটি পুনরুত্পাদন করার জন্য পর্যাপ্ত নয়FULL OUTER JOIN
। আরও বিশ্বস্ত এমুলেশন পেতে, আমাদের একটি UNION ALL
সেট অপারেটর প্রয়োজন , এবং যে কোনও প্রশ্নের জন্য একটি অ্যান্টি-জয়েন্ট প্যাটার্ন প্রয়োজন। পাভেল লেকিকের (উপরে) মন্তব্যটি সঠিক কোয়েরি প্যাটার্ন দেয় ।
উত্তর যে পাবলো সান্তা ক্রুজ দিয়েছে তা সঠিক; যাইহোক, যদি কেউ এই পৃষ্ঠাতে হোঁচট খায় এবং আরও ব্যাখ্যা চান, তবে এখানে একটি বিশদ বিচ্ছেদ।
ধরুন আমাদের নীচের সারণি রয়েছে:
-- t1
id name
1 Tim
2 Marta
-- t2
id name
1 Tim
3 Katarina
একটি অভ্যন্তরীণ যোগদান, এর মতো:
SELECT *
FROM `t1`
INNER JOIN `t2` ON `t1`.`id` = `t2`.`id`;
আমাদের উভয় সারণীতে প্রদর্শিত কেবল রেকর্ডগুলি পেতে হবে:
1 Tim 1 Tim
অভ্যন্তরীণ যোগদানগুলিতে কোনও দিক থাকে না (যেমন বাম বা ডান মতো) কারণ তারা সুস্পষ্টভাবে দ্বি নির্দেশমূলক - আমাদের উভয় পক্ষের ম্যাচ প্রয়োজন।
অন্যদিকে, বাইরের সাথে যোগ দেয় এমন রেকর্ডগুলি সন্ধানের জন্য যা অন্য টেবিলে ম্যাচ নাও থাকতে পারে finding যেমন, আপনাকে কোন দিকটি নির্দিষ্ট করতে হবে এর যোগদান একটি অনুপস্থিত রেকর্ড অনুমোদিত হয়।
LEFT JOIN
এবং RIGHT JOIN
জন্য সাধারণভাবে সংক্ষেপে হয় LEFT OUTER JOIN
এবংRIGHT OUTER JOIN
; আমি নীচে তাদের পুরো নামগুলি ব্যবহার করব অভ্যন্তরীণ যোগগুলিতে বনাম যোগদানের ধারণাটিকে শক্তিশালী করতে।
একটি বাম বাহ্যিক জোড়, এর মতো:
SELECT *
FROM `t1`
LEFT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`;
... ডান টেবিলের সাথে ম্যাচ আছে কিনা তা নির্বিশেষে আমাদের বাম টেবিল থেকে সমস্ত রেকর্ড পেতে হবে:
1 Tim 1 Tim
2 Marta NULL NULL
ডান বাহ্যিক যোগদান, এর মতো:
SELECT *
FROM `t1`
RIGHT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`;
... বাম টেবিলে তাদের ম্যাচ আছে কি না তা নির্বিশেষে আমাদের ডান টেবিল থেকে সমস্ত রেকর্ড পেতে হবে:
1 Tim 1 Tim
NULL NULL 3 Katarina
একটি সম্পূর্ণ বাহ্যিক যোগদান আমাদের উভয় টেবিল থেকে সমস্ত রেকর্ড দেবে, অন্য টেবিলে তাদের ম্যাচ আছে কি না, উভয় পক্ষের যেখানে NUL আছে সেখানে মিল নেই। ফলাফলটি দেখতে এই রকম হবে:
1 Tim 1 Tim
2 Marta NULL NULL
NULL NULL 3 Katarina
তবে পাবলো সান্তা ক্রুজ যেমন উল্লেখ করেছেন, মাইএসকিউএল এটি সমর্থন করে না। আমরা এটির মতো বাম জোড় এবং ডান জোড়ার একটি ইউনিয়ন করে অনুকরণ করতে পারি:
SELECT *
FROM `t1`
LEFT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`
UNION
SELECT *
FROM `t1`
RIGHT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`;
আপনি এর UNION
অর্থ হিসাবে ভাবতে পারেন "এই উভয় কোয়েরি চালান, তারপরে ফলাফল একে অপরের উপরে রেখে দিন"; সারিগুলির কিছু প্রথম কোয়েরি থেকে এবং কিছু দ্বিতীয় থেকে আসবে।
এটি লক্ষ করা উচিত যে UNION
মাইএসকিউএল-এ একটি হুবহু ডুপ্লিকেটগুলি মুছে ফেলবে: টিম এখানে উভয় প্রশ্নের মধ্যে উপস্থিত হবে, তবে কেবলমাত্র ফলাফলের ফলাফল UNION
তাকে একবারে তালিকাভুক্ত করে। আমার ডাটাবেস গুরু সহকর্মী মনে করেন যে এই আচরণের উপর নির্ভর করা উচিত নয়। সুতরাং এটি সম্পর্কে আরও স্পষ্ট করে বলতে, আমরা WHERE
দ্বিতীয় ক্যোয়ারিতে একটি ধারা যুক্ত করতে পারি :
SELECT *
FROM `t1`
LEFT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`
UNION
SELECT *
FROM `t1`
RIGHT OUTER JOIN `t2` ON `t1`.`id` = `t2`.`id`
WHERE `t1`.`id` IS NULL;
অন্যদিকে, আপনি যদি কোনও কারণে সদৃশ দেখতে চান তবে আপনি ব্যবহার করতে পারেন UNION ALL
।
FULL OUTER JOIN
। সেভাবে প্রশ্ন করা, এবং সেই সদৃশগুলি সরানোর জন্য ইউএনআইএন ব্যবহার করে কোনও সমস্যা নেই। তবে সত্যিকারের FULL OUTER JOIN
একটির প্রতিলিপি তৈরি করতে আমাদের বিরোধী-যুক্ত হওয়ার জন্য একটি প্রশ্নের প্রয়োজন।
UNION
অভিযান সেই নকলগুলি সরিয়ে ফেলবে; তবে এটি ডুপ্লিকেট সারি সহ সমস্ত সদৃশ সারিগুলিও সরিয়ে দেয় যা সম্পূর্ণ আউটয়ার জয়েন দ্বারা ফিরিয়ে দেওয়া হবে। অনুকরণ করতে a FULL JOIN b
, সঠিক প্যাটার্নটি হ'ল (a LEFT JOIN b) UNION ALL (b ANTI JOIN a)
।
একটি union
কোয়েরি ব্যবহার করে সদৃশগুলি মুছে ফেলা হবে, এবং এটি এর আচরণের থেকে আলাদা full outer join
যা কখনই কোনও সদৃশ সরিয়ে দেয় না:
[Table: t1] [Table: t2]
value value
------- -------
1 1
2 2
4 2
4 5
এটির প্রত্যাশিত ফলাফল full outer join
:
value | value
------+-------
1 | 1
2 | 2
2 | 2
Null | 5
4 | Null
4 | Null
এই ব্যবহারের ফল left
এবং right Join
সঙ্গে union
:
value | value
------+-------
Null | 5
1 | 1
2 | 2
4 | Null
আমার প্রস্তাবিত ক্যোয়ারী হ'ল:
select
t1.value, t2.value
from t1
left outer join t2
on t1.value = t2.value
union all -- Using `union all` instead of `union`
select
t1.value, t2.value
from t2
left outer join t1
on t1.value = t2.value
where
t1.value IS NULL
উপরের ক্যোয়ারির ফলাফল যা প্রত্যাশিত ফলাফল হিসাবে একই:
value | value
------+-------
1 | 1
2 | 2
2 | 2
4 | NULL
4 | NULL
NULL | 5
@ স্টিভ চেম্বারস : [অনেক ধন্যবাদ সহ মন্তব্য থেকে!]
দ্রষ্টব্য: দক্ষতার জন্য এবং এ হিসাবে একই ফলাফল উত্পন্ন করার জন্য এটি উভয়ই সেরা সমাধান হতে পারেFULL OUTER JOIN
। এই ব্লগ পোস্টটি এটিকে আরও ভালভাবে ব্যাখ্যা করেছে - পদ্ধতি 2 থেকে উদ্ধৃতি দিতে: "এটি সদৃশ সারিগুলি সঠিকভাবে পরিচালনা করে এবং যা করা উচিত নয় তা অন্তর্ভুক্ত করে নাUNION ALL
plain প্লেইনের পরিবর্তে এটি ব্যবহার করা দরকারUNION
যা আমার রাখা নকলগুলি মুছে ফেলবে This এটি বড় ফলাফলের সেটগুলিতে উল্লেখযোগ্যভাবে আরও দক্ষ হতে পারে, যেহেতু নকলকে বাছাই এবং মুছে ফেলার দরকার নেই। "
আমি আরও একটি সমাধান যোগ করার সিদ্ধান্ত নিয়েছি যা full outer join
ভিজ্যুয়ালাইজেশন এবং গণিত থেকে আসে , এটি উপরের চেয়ে ভাল নয় তবে আরও পাঠযোগ্য:
ফুল বাইরের মানে যোগদানের
(t1 ∪ t2)
সমস্ত:t1
বাt2
(t1 ∪ t2) = (t1 ∩ t2) + t1_only + t2_only
উভয় সমস্ত:t1
এবংt2
প্লাস সমস্তt1
যে নেইt2
এবং প্লাস সবt2
যে নেইt1
:
-- (t1 ∩ t2): all in both t1 and t2
select t1.value, t2.value
from t1 join t2 on t1.value = t2.value
union all -- And plus
-- all in t1 that not exists in t2
select t1.value, null
from t1
where not exists( select 1 from t2 where t2.value = t1.value)
union all -- and plus
-- all in t2 that not exists in t1
select null, t2.value
from t2
where not exists( select 1 from t1 where t2.value = t1.value)
FULL OUTER JOIN
। এই ব্লগ পোস্টটি এটিকে আরও ভালভাবে ব্যাখ্যা করেছে - পদ্ধতি 2 থেকে উদ্ধৃতি দেওয়ার জন্য: "এটি সদৃশ সারিগুলি সঠিকভাবে পরিচালনা করে এবং যা করা উচিত নয় তা অন্তর্ভুক্ত করে না plain প্লেইন ইউনিয়নের পরিবর্তে ইউনিয়ন সবগুলি ব্যবহার করা দরকার, যা আমি নকলগুলি অপসারণ করতে চাই রাখুন। বৃহত ফলাফলের সেটগুলিতে এটি উল্লেখযোগ্যভাবে আরও দক্ষ হতে পারে, যেহেতু নকলকে বাছাই এবং মুছে ফেলার দরকার নেই। "
মাইএসকিউএল-এ ফুল-আউটার-যোগ সিনট্যাক্স নেই। আপনাকে নিম্নে বাম যোগ এবং ডান যোগ দিতে উভয়ই অনুকরণ করতে হবে-
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
তবে মাইএসকিএল-তেও একটি রাইট জয়েন্ট সিনট্যাক্স নেই। মাইএসকিউএল এর মতে বাইরের সরলীকরণ যোগদান , ডান যোগদানের সমতুল্য বাম রূপান্তরিত হয় T1 এবং T2 সুইচিং দ্বারা যোগদানের FROM
এবং ON
ক্যোয়ারীতে দফা। সুতরাং, মাইএসকিএল ক্যোয়ারী অপ্টিমাইজার মূল প্রশ্নটি নিম্নলিখিতটিতে অনুবাদ করে -
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION
SELECT * FROM t2
LEFT JOIN t1 ON t2.id = t1.id
এখন, মূল কোয়েরিটি যেমন আছে তেমন লেখার কোনও ক্ষতি নেই, তবে বলুন যে আপনার কাছে WHERE ধারাটির মতো ভবিষ্যদ্বাণী রয়েছে, যা পূর্বে যোগদানের পূর্বে বা একটি শৃঙ্খলে একটি ভবিষ্যদ্বাণীী ON
, যা একটি সময়কালীন যোগদান পূর্বাভাস হয়, তবে আপনি শয়তানকে একবার দেখে নিতে চাইবে; যা বিস্তারিত আছে।
মাইএসকিউএল ক্যোয়ারী অপ্টিমাইজার নিয়মিতভাবে পূর্বাভাসগুলি পরীক্ষা করে যদি সেগুলি বাতিল হয় । এখন, যদি আপনি সঠিক যোগদান করেন তবে টি 1 থেকে কলামটিতে পূর্বাভাস দিয়েছিলেন, তবে আপনি নাল-প্রত্যাখ্যাত পরিস্থিতিতে দৌড়ানোর ঝুঁকিতে পড়তে পারেন ।
উদাহরণস্বরূপ, আপনার নিম্নলিখিত কোয়েরি -
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.col1 = 'someValue'
UNION
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
WHERE t1.col1 = 'someValue'
ক্যোরি অপটিমাইজার- এর দ্বারা নিম্নলিখিতটিতে অনুবাদ হয়ে যায় -
SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
WHERE t1.col1 = 'someValue'
UNION
SELECT * FROM t2
LEFT JOIN t1 ON t2.id = t1.id
WHERE t1.col1 = 'someValue'
সুতরাং সারণির ক্রম পরিবর্তন হয়েছে, তবে প্রিডিকেটটি এখনও টি 1 এ প্রয়োগ করা হয়েছে, তবে টি 1 এখন 'অন' ধারাটিতে রয়েছে। যদি t1.col1 NOT NULL
কলাম হিসাবে সংজ্ঞায়িত করা হয় , তবে এই কোয়েরিটি বাতিল-প্রত্যাখ্যাত হবে ।
যে কোনও বাহ্যিক-যোগ (বাম, ডান, পূর্ণ) নাল-প্রত্যাখ্যাত তা মাই এসকিএল দ্বারা অভ্যন্তরীণ-যোগে রূপান্তরিত হয়।
সুতরাং আপনি যে ফলাফলগুলির প্রত্যাশা করছেন তা মাইএসকিএল থেকে ফিরে আসা থেকে সম্পূর্ণ আলাদা হতে পারে। আপনি এটি মাইএসকিএল রাইটস জোনে একটি ত্রুটি মনে করতে পারেন, তবে এটি ঠিক নয়। এটি ঠিক কিভাবে MySQL ক্যোয়ারী-অপ্টিমাইজার কাজ করে। সুতরাং বিকাশকারী ইনচার্জ যখন তিনি কোয়েরিটি তৈরি করছেন তখন এই সংক্ষিপ্তসারগুলিতে মনোযোগ দিতে হবে।
এসকিউএলাইটে আপনার এটি করা উচিত:
SELECT *
FROM leftTable lt
LEFT JOIN rightTable rt ON lt.id = rt.lrid
UNION
SELECT lt.*, rl.* -- To match column set
FROM rightTable rt
LEFT JOIN leftTable lt ON lt.id = rt.lrid
উপরের উত্তরগুলির মধ্যে কোনটিই প্রকৃতপক্ষে সঠিক নয়, কারণ সদৃশ মান রয়েছে যখন তারা শব্দার্থবিজ্ঞান অনুসরণ করে না।
(এই সদৃশ থেকে ) যেমন একটি প্রশ্নের জন্য :
SELECT * FROM t1 FULL OUTER JOIN t2 ON t1.Name = t2.Name;
সঠিক সমতুল্য হ'ল:
SELECT t1.*, t2.*
FROM (SELECT name FROM t1 UNION -- This is intentionally UNION to remove duplicates
SELECT name FROM t2
) n LEFT JOIN
t1
ON t1.name = n.name LEFT JOIN
t2
ON t2.name = n.name;
NULL
মানগুলির সাথে কাজ করার জন্য আপনার যদি NULL
এটির প্রয়োজন হয় (যা প্রয়োজনীয়ও হতে পারে), তবে- তুলনায় <=>
অপেক্ষাকৃত নিরাপদ তুলনা অপারেটরটি ব্যবহার করুন =
।
FULL OUTER JOIN
হলে এটি তার চেয়ে আলাদা ফলাফল দিতে পারে name
। union all
বিরোধী-যোগ প্যাটার্ন সঙ্গে ক্যোয়ারী বাইরের সঠিকভাবে আচরণ যোগদানের নকল করা উচিত, কিন্তু যা সমাধান আরো উপযুক্ত প্রসঙ্গ এবং সীমাবদ্ধতার যে টেবিল সক্রিয় উপর নির্ভর করে।
union all
, তবে সেই উত্তরটি প্রথম বা দ্বিতীয় কোয়েরিতে একটি অ্যান্টি-জয়েন প্যাটার্ন মিস করে যা বিদ্যমান নকলগুলি রাখে তবে নতুন উত্তর যুক্ত হওয়া থেকে বাধা দেয়। প্রসঙ্গের উপর নির্ভর করে অন্যান্য সমাধানগুলি (এটির মতো) আরও উপযুক্ত হতে পারে।
আরও স্পষ্টতার জন্য shA.t এর প্রশ্নের পরিবর্তিত হয়েছে:
-- t1 left join t2
SELECT t1.value, t2.value
FROM t1 LEFT JOIN t2 ON t1.value = t2.value
UNION ALL -- include duplicates
-- t1 right exclude join t2 (records found only in t2)
SELECT t1.value, t2.value
FROM t1 RIGHT JOIN t2 ON t1.value = t2.value
WHERE t2.value IS NULL
ক্রস যোগদানের সমাধান সম্পর্কে আপনি কী বলবেন ?
SELECT t1.*, t2.*
FROM table1 t1
INNER JOIN table2 t2
ON 1=1;
select (select count(*) from t1) * (select count(*) from t2))
ফলাফল সেটটিতে সারি সহ সমস্ত সম্ভাব্য সংমিশ্রণের সেট উপস্থাপন করবে।
SELECT
a.name,
b.title
FROM
author AS a
LEFT JOIN
book AS b
ON a.id = b.author_id
UNION
SELECT
a.name,
b.title
FROM
author AS a
RIGHT JOIN
book AS b
ON a.id = b.author_id
আমি প্রতিক্রিয়াটি স্থির করেছি, এবং কার্যগুলিতে সমস্ত সারি অন্তর্ভুক্ত রয়েছে (পাভেল লিকের প্রতিক্রিয়ার ভিত্তিতে)
(
SELECT a.* FROM tablea a
LEFT JOIN tableb b ON a.`key` = b.key
WHERE b.`key` is null
)
UNION ALL
(
SELECT a.* FROM tablea a
LEFT JOIN tableb b ON a.`key` = b.key
where a.`key` = b.`key`
)
UNION ALL
(
SELECT b.* FROM tablea a
right JOIN tableb b ON b.`key` = a.key
WHERE a.`key` is null
);
tablea
যা থেকে কোনও মিল নেই tableb
এবং বিপরীতে। আপনি চেষ্টা করেছেন UNION ALL
, যা কেবল তখনই কার্যকর হবে যদি এই দুটি টেবিল সমানভাবে কলামগুলি অর্ডার করে, যা গ্যারান্টিযুক্ত নয়।
উত্তর:
SELECT * FROM t1 FULL OUTER JOIN t2 ON t1.id = t2.id;
নিম্নলিখিত হিসাবে পুনরায় তৈরি করা যেতে পারে:
SELECT t1.*, t2.*
FROM (SELECT * FROM t1 UNION SELECT name FROM t2) tmp
LEFT JOIN t1 ON t1.id = tmp.id
LEFT JOIN t2 ON t2.id = tmp.id;
একটি ইউনিয়ন বা ইউনিয়ন সমস্ত উত্তর ব্যবহার করে বেস টেবিলগুলির নকল এন্ট্রি রয়েছে এমন প্রান্তের মামলাটি কভার করে না।
ব্যাখ্যা:
একটি প্রান্তের কেস রয়েছে যেটি একটি ইউনিয়ন বা ইউনিয়ন সব কভার করতে পারে না। আমরা এটি মাইএসকিএলে পরীক্ষা করতে পারি না কারণ এটি সম্পূর্ণ আউট জয়েনগুলিকে সমর্থন করে না, তবে আমরা এটি একটি ডাটাবেসে চিত্রিত করতে পারি যা এটি সমর্থন করে:
WITH cte_t1 AS
(
SELECT 1 AS id1
UNION ALL SELECT 2
UNION ALL SELECT 5
UNION ALL SELECT 6
UNION ALL SELECT 6
),
cte_t2 AS
(
SELECT 3 AS id2
UNION ALL SELECT 4
UNION ALL SELECT 5
UNION ALL SELECT 6
UNION ALL SELECT 6
)
SELECT * FROM cte_t1 t1 FULL OUTER JOIN cte_t2 t2 ON t1.id1 = t2.id2;
This gives us this answer:
id1 id2
1 NULL
2 NULL
NULL 3
NULL 4
5 5
6 6
6 6
6 6
6 6
ইউনিয়ন সমাধান:
SELECT * FROM cte_t1 t1 LEFT OUTER JOIN cte_t2 t2 ON t1.id1 = t2.id2
UNION
SELECT * FROM cte_t1 t1 RIGHT OUTER JOIN cte_t2 t2 ON t1.id1 = t2.id2
একটি ভুল উত্তর দেয়:
id1 id2
NULL 3
NULL 4
1 NULL
2 NULL
5 5
6 6
ইউনিয়ন সব সমাধান:
SELECT * FROM cte_t1 t1 LEFT OUTER join cte_t2 t2 ON t1.id1 = t2.id2
UNION ALL
SELECT * FROM cte_t1 t1 RIGHT OUTER JOIN cte_t2 t2 ON t1.id1 = t2.id2
ভুলও।
id1 id2
1 NULL
2 NULL
5 5
6 6
6 6
6 6
6 6
NULL 3
NULL 4
5 5
6 6
6 6
6 6
6 6
যেখানে এই ক্যোয়ারী:
SELECT t1.*, t2.*
FROM (SELECT * FROM t1 UNION SELECT name FROM t2) tmp
LEFT JOIN t1 ON t1.id = tmp.id
LEFT JOIN t2 ON t2.id = tmp.id;
নিম্নলিখিত দেয়:
id1 id2
1 NULL
2 NULL
NULL 3
NULL 4
5 5
6 6
6 6
6 6
6 6
ক্রমটি আলাদা, তবে অন্যথায় সঠিক উত্তরটির সাথে মেলে।
UNION ALL
সমাধানটির ভুল ব্যাখ্যা দেয় । এছাড়াও, এটি একটি সমাধান ব্যবহার করে উপস্থাপন করে UNION
যা বৃহত উত্সের টেবিলগুলিতে ধীর গতিতে হবে কারণ প্রয়োজনীয় ডি-নকলের কারণে। অবশেষে, এটি সংকলন করবে না, কারণ ক্ষেত্রটি id
সাবকোয়ারিতে নেই tmp
।
UNION ALL
সমাধান: ... এটিও ভুল।" আপনি যে কোডটি উপস্থাপন করেছেন তা ডান-যোগ ( where t1.id1 is null
) থেকে অন্তর্ভুক্ত-বর্জনকে ছেড়ে দেয় যা অবশ্যই সরবরাহ করা উচিত UNION ALL
। যার অর্থ হল, আপনার সমাধানটি অন্য সকলকে ট্রাম্প করে, কেবল তখনই যখন এইগুলি সমাধানগুলির মধ্যে একটির ভুলভাবে প্রয়োগ করা হয়। "নমনীয়তা" তে, পয়েন্টটি নেওয়া হয়েছে। এটা ছিল কৃতজ্ঞ, আমার ক্ষমা।
এসকিউএল স্ট্যান্ডার্ডটি বলছে full join on
যে inner join on
সারিগুলি union all
তুলনাহীন বাম টেবিলের সারিগুলি নাল দ্বারা প্রসারিত union all
ডান টেবিল সারিগুলি নাল দ্বারা প্রসারিত। অর্থাৎ inner join on
সারি union all
সারিগুলিতে left join on
কিন্তু inner join on
union all
সারিগুলিতে right join on
নয় তবে নেই inner join on
।
অর্থাত left join on
সারি union all
right join on
সারি নেই inner join on
। অথবা আপনি যদি জানেন তাঁরা আপনার inner join on
ফলাফলের "তাহলে একটি নির্দিষ্ট ডানদিকের সারণী কলামে নাল থাকতে পারে না right join on
নেই সারি inner join on
" সারি হয় right join on
সঙ্গে on
শর্ত দ্বারা বর্ধিত and
কলামের is null
।
অর্থাৎ একইভাবে right join on
union all
উপযুক্ত left join on
সারি।
থেকে মধ্যবর্তী "ভিতরের JOIN" এবং "বহিঃস্থ সংযোগ" পার্থক্য কি? :
(এসকিউএল স্ট্যান্ডার্ড 2006 এসকিউএল / ফাউন্ডেশন 7.7 সিন্ট্যাক্স বিধি 1, সাধারণ বিধি 1 বি, 3 সি ও ডি, 5 খ।)