ورود

View Full Version : سوال: سوال، پرس و جو



omid.n1990
شنبه 09 شهریور 1392, 14:30 عصر
سلام، من دو تا پرس وچو نیاز پیدا کردم نمی‌دونم چطوری انجامش بدم
فرض کنید یک جدول دارم با دو فیلد، یکی نام یکی هم اسم درس پاس شده است. به صورت زیر

نام / اسم درس
علی/ادبیات
علی/زبان
علی/انقلاب
علی/تربیت بدنی
علی/کارآموزی
حسن/فیزیک
حسن/ریاضی
حسن/ادبیات
حسن/ کارآموزی

حالا دو نوع پرس و جوی زیر رو واسه این نیاز دارم نمی‌دونم چیکار کنم
یک. اسم کسانی که هم ادبیات و هم انقلاب را پاس کردن بدهد مثلا این رو نوشتم، اما دنبال بهترش هستم

SELECT name
FROM tblPass
WHERE (dars = 'انقلاب') OR
(dars = 'ادبیات')
GROUP BY name
HAVING (COUNT(*) = 2)
دو. اسم کسانی که تنها ترکیبی از ادبیات، انقلاب و فیزیک را پاس کرده‌اند (یعنی کسانی که فقط یکی از سه تا، یا دو تا از این سه تا یا هرسه مورد رو پاس کرده باشند و به جز این سه درس هیچ درس دیگری پاس نکرده باشند.)
و برای دومی:


SELECT name
FROM tblPass
WHERE (dars = 'a') OR
(dars = 'c')
GROUP BY name
HAVING (COUNT(*) IN
(SELECT COUNT(*) AS Expr1
FROM tblPass AS tblPass_1
WHERE (tblpass.name = name)
GROUP BY name))
تشکر

mostafa_shaeri_tj
چهارشنبه 13 شهریور 1392, 22:10 عصر
واسه کویری اولی . اسم افرادی که هم ادبیات و هم انقلاب پاس کردن :



SELECT t1.name FROM `yourtbl` t1 inner join `yourtbl` t2
on (t1.name=t2.name) WHERE t1.`lesson`='adabiat' and t2.`lesson`='enqelab'