国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 临桂县| 黔西| 莱西市| 河南省| 青河县| 陈巴尔虎旗| 同心县| 静安区| 唐山市| 芮城县| 安塞县| 乌审旗| 夏河县| 遂昌县| 尉氏县| 普洱| 彭山县| 平陆县| 应城市| 阳信县| 视频| 屏南县| 海城市| 大理市| 宁河县| 万全县| 兰溪市| 元江| 汉寿县| 社旗县| 平乐县| 海伦市| 高唐县| 陇西县| 昌吉市| 新源县| 监利县| 奇台县| 汾西县| 西丰县| 达拉特旗|