如何进行内部联接查询以获取多个选定的表列

问题描述 投票:0回答:1

我只是制定项目学校的管理。现在我只是查询以检索其他表列。这是我的查询:

ALTER PROCEDURE [dbo].[GetTeacherList]
(
    @teacherid varchar(5) = null,
    @classid varchar(5) = null,
    @sectionid varchar(5) = null,
    @subjectid varchar(5) = null
)
AS
BEGIN

    SET NOCOUNT ON;
    select *,right('00000' + CAST(t.[PK_PID] AS varchar(5)) ,5) as ID, c.ClassName, su.SubjectName, s.SectionName
    from teachers t 

        inner join teacherclassassign tc on t.PK_PID = tc.TeacherID or (t.PK_PID is null and tc.TeacherID is null ) 
        inner join classes c on c.PK_PID = tc.ClassID or (c.PK_PID is not null and tc.ClassID is null)
        inner join sections s on s.PK_PID = tc.SectionID or (s.PK_PID is not null and tc.SectionID is null)
        inner join subjects su on su.PK_PID = tc.SubjectID or (su.PK_PID is not null and tc.SubjectID is null)

    where 1=1

    and (@teacherid is null or tc.[TeacherID] = CONVERT(INT,@teacherid))
    and (@classid is null or tc.[ClassID] = CONVERT(INT,@classid))
    and (@sectionid is null or tc.[SectionID] = CONVERT(INT,@sectionid))
    and (@subjectid is null or tc.[SubjectID] = CONVERT(INT,@subjectid))

    order by t.PK_PID asc
END

如何返回我两行,但是我希望从表教师那里得到所有行。

这里是我想要的行数据:

enter image description here

这里是老师的全部数据:

enter image description here

我如何达到这个结果。请大家帮我。

sql tsql asp.net-4.0
1个回答
0
投票

[您需要所有教师都需要用LEFT Join替换第一个内部join。

下面我更改了查询,看看是否可以解决问题

将NOCOUNT设为ON;选择*,right('00000'+ CAST(t。[PK_PID] AS varchar(5)),5)作为ID,c.ClassName,su.SubjectName,s.SectionName来自老师们t

    LEFT join teacherclassassign tc on t.PK_PID = tc.TeacherID or (t.PK_PID is null and tc.TeacherID is null ) 
    inner join classes c on c.PK_PID = tc.ClassID or (c.PK_PID is not null and tc.ClassID is null)
    inner join sections s on s.PK_PID = tc.SectionID or (s.PK_PID is not null and tc.SectionID is null)
    inner join subjects su on su.PK_PID = tc.SubjectID or (su.PK_PID is not null and tc.SubjectID is null)

where 1=1

and (@teacherid is null or tc.[TeacherID] = CONVERT(INT,@teacherid))
and (@classid is null or tc.[ClassID] = CONVERT(INT,@classid))
and (@sectionid is null or tc.[SectionID] = CONVERT(INT,@sectionid))
and (@subjectid is null or tc.[SubjectID] = CONVERT(INT,@subjectid))

order by t.PK_PID asc

END

© www.soinside.com 2019 - 2024. All rights reserved.