国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SqlServer 巧妙解決多條件組合查詢

2024-08-31 00:57:09
字體:
來源:轉載
供稿:網(wǎng)友
開發(fā)中經(jīng)常會遇得到需要多種條件組合查詢的情況,比如有三個表,年級表Grade(GradeId,GradeName),班級Class(ClassId,ClassName,GradeId),學員表Student(StuId,StuName,ClassId),現(xiàn)要求可以按年級Id、班級Id、學生名,這三個條件可以任意組合查詢學員信息。

  做法不止一種,這里提供一種巧妙的使用一條查詢來實現(xiàn)的辦法,我們來寫成一個過程,如下:

復制代碼 代碼如下:


create proc up_select_student_combocondition
@gradeId int,
@classId int,
@stuName nvarchar(10)
as
select s.*,c.classname,g.gradename from student s join class c on s.classid=c.classid join grade g on c.gradeid=g.gradeid
where
(@gradeId=-1 or g.gradeid=@gradeId) and
(@classId=-1 or c.classid=@classId) and
(@stuName='' or s.stuName=@stuName)
go


--那么:
 exec up_select_student_combocondition -1,-1,'' --這是查詢所有學員信息
 exec up_select_student_combocondition 2,-1,'' --這是查詢年級Id為2的學員信息
exec up_select_student_combocondition -1,4,'' --這是查詢班級Id為4的學員信息
exec up_select_student_combocondition 2,4,'' --這是查詢年級Id為2且班級Id為4的學員信息
--etc....
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 红河县| 神农架林区| 江阴市| 玉田县| 甘孜县| 布尔津县| 板桥市| 怀柔区| 阜阳市| 青田县| 石嘴山市| 忻州市| 延寿县| 英超| 铜鼓县| 林口县| 布拖县| 塘沽区| 五指山市| 苏尼特右旗| 土默特左旗| 云浮市| 漾濞| 封丘县| 平舆县| 开阳县| 清涧县| 揭阳市| 瑞金市| 清水河县| 定州市| 银川市| 荥经县| 玉环县| 武鸣县| 炉霍县| 荣昌县| 邯郸市| 兴文县| 阆中市| 中方县|