استفاده از دستور Union در Mysql

گاهی اوقات ساختار دیتابیس باید بصورتی باشد که یک سری اطلاعات در ۲ یا چند جدول ذخیره شده و حالا میخواهیم گزارشی از یک عبارت بگیرم .

به نظر من یکی از کاربردهای این دستور در جستجو در جدول های آرشیو است .

SELECT  name,price FROM tb1 a


where a.name = "vahid"

UNION  
SELECT  name,price FROM tb2 b
 
 
where b.name = "vahid"

دستور فوق شما عبارت vahid را در ۲ جدول نمایش می دهد و حاصل آن را در هر ۲ جدول نمایش می دهد .

نکاتی در مورد union :

۱- باید موارد Select شده در هر دو Select یکسان باشد مثلا من در مثال فوق ۲ فیلد name,price را انتخاب کرده ام

۲- فیلد های انتخاب شده باید از یک نوع باشد

۳-شما نمی توانید جستجو را بر اساس یک فیلد که در یکی از جدول ها وجود ندارد بدست آورید باید آن فیلد که در where قرار میگیرد در هر ۲ جدول به صورت منطقی وجود داشته باشد

۴- شما به جای union میتوانید از union all نیز استفاده کنید اما استفاده از union all موارد تکراری را که برابر فیلد Where میباشد را حذف میکند.

 

مثلا اگر در جدول  اول مقدار name = vahid , price =2000  باشد و در جدول دوم name = vahid , price =1000 باشد تنها مقدار جدول اول که معادلSelect  اول میباشد را نمایش میدهد.

 

فرض کنید میخواهید نتایج هر ۲ جدول را در هم ادغام کنید مثال فوق که اجرا میشود نتیجه زیر را نمایش میدهد

vahid  —- ۱۰۰۰

vahid —- 2000

 

اگر شما بخواهید هر جمع حاصل هر ۲ جدول را نمایش بدهد باید آنها را در یک Sub query قرار دهید

SELECT  

sum(t.ss) from

(

SELECT name,sum(price) as ss FROM tb1 a

where a.name = "vahid"
 
UNION  
SELECT  name,sum(price) as ss FROM tb2 b
 
 
where b.name = "vahid"
) t

 

توضیح برنامه فوق این است که دو Select موجود در Subquery جمع نتایج خود را بدست آوردند و سپس در متفیر ss قرار دادند در داخل Subquery ما همان برنامه قبل را نوشتیم اما حالا میخواهیم جمع نتایج هر ۲ جدول را جمع بزنیم . مقدار t حامل همان نتایج قبل است و آن را به عنوان یک جدول فرض می بیند وقتی که ما در Select اصلی که در ابتدای برنامه قرار دارد sum(t.ss) را وارد میکنیم جمع ۲ نتیجه را یکی میکند و حاصل مقدار زیر است

vahid  —- ۳۰۰۰

 

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *