2017-09-27 67 views
0

先生,下面是我的SQL查询,然后用查询结果 & 的两个图像所需的输出SQL查询来获取结构化结果

正如你所看到的结果图像,我已经得到这个输出执行以下查询。

有第二张图片要求输出。我需要以该格式显示输出。由于第一部门名称应位于以下顶部&项目详细信息对应于该部门。每个部门都应该重复相同的周期。

我该怎么做到这一点?

SQL代码:

DECLARE @ColName varchar(20)=null, 
     @Query varchar(MAX)=null, 
     @DepartmentName varchar(50)=null, 
     @deptt_code varchar(4)=null, 
     @DistrictId varchar(4)='0001', 
     @Deptt_Id char(4)=null, 
     @stYear varchar(4)=null, 
     @cYear varchar(4)=null, 
     @yr varchar(9)='2017-2018', 
     @tno int 

BEGIN 

set @stYear = SUBSTRING(@yr,0,5); 
set @cYear = SUBSTRING(@yr,6,4); 

--CREATE DYNAMIC TABLE WITH COLs 
DECLARE @DepartmentTable table 
(
    department_name varchar(50), 
    department_code varchar(4) 
); 
DECLARE @ProjectTable table 
(
    project_name varchar(130), 
    project_code varchar(15), 
    department_code varchar(4), 
    department_name varchar(50), 
    district_code varchar(4), 
    district_name varchar(30), 
    tehsil_code varchar(6), 
    tehsil_name varchar(30), 
    service_code varchar(3), 
    [service_name] varchar(30), 
    sector_code varchar(3), 
    sector_name varchar(30), 
    project_start_year varchar(8), 
    project_compl_year varchar(8), 
    financial_year varchar(9) 
); 

--Insert into Department Table 
INSERT INTO @DepartmentTable (department_code, department_name) 
select deptt_code,deptt_name+'('+ RTRIM(LTRIM(deptt_short))+')' as dept_name from m_Department 
    where deptt_code in (select distinct department_code from t_Project_Details where [email protected] 
    and [email protected]); 


--Insert into Project Table With Corresponding Department Name & Code 
    insert into @ProjectTable (
            department_code, 
            project_code, 
            project_name, 
            department_name, 
            district_code, 
            district_name, 
            tehsil_code, 
            tehsil_name, 
            service_code, 
            [service_name], 
            sector_code, 
            sector_name, 
            project_start_year, 
            project_compl_year, 
            financial_year 
            ) 
     SELECT pd.department_code, 
       pd.project_Code, 
       pd.project_name, 
       d.deptt_name, 
       pd.district_id, 
       di.district_name, 
       pd.tehsil_id, 
       t.tehsil_name, 
       pd.service_code, 
       s.[service_name], 
       pd.sector_code, 
       se.sector_name, 
       CONVERT(varchar,YEAR(pd.project_initiation_fin_from_yr)) + ' ' + CONVERT(varchar(3),pd.project_initiation_fin_from_yr,100) as project_start_year, 
       CONVERT(varchar,YEAR(pd.project_initiation_fin_to_yr)) + ' ' + CONVERT(varchar(3),pd.project_initiation_fin_to_yr,100) as project_compl_year, 
       pd.financial_year 

     FROM t_Project_Details pd 

     INNER JOIN m_Department d 
     ON d.deptt_code=pd.department_code 

     INNER JOIN m_Service s 
     ON s.service_code = pd.service_code 

     INNER JOIN m_Sector se 
     ON se.sector_code=pd.sector_code 

     INNER JOIN m_District di 
     ON di.district_code=pd.district_id 

     INNER JOIN m_Tehsil t 
     ON t.tehsil_code = pd.tehsil_id 

     WHERE 
       [email protected] and 
       [email protected]; 

--select all from Department Table; 
select * from @ProjectTable; 
END 

查询结果图片:https://drive.google.com/open?id=0Bxn7UXgmstmRaS1qX21kbjlwZzg

所需的输出图像:https://drive.google.com/open?id=0Bxn7UXgmstmRekJkUWhBcmNCbk0

+0

请勿包含图像来代替实际的文本代码。此外,您的问题很长,您的工作是告诉我们实际问题在哪里。 –

+0

先生,我已经包含的图片只是告诉你我得到了什么,我需要什么。 –

+0

问题是我无法按照我在输出图像中提供的指定格式获取输出。它可以实现吗? –

回答

0

你需要输出的是表示层的问题; SQL可以返回结果,但不能使一行包含一个内容,并且以下行以不同的格式包含许多不同的内容。

SQL结果集将在每个具有相同数据类型的所有行中包含相同数量的列。

使用类似SSRS的东西来实现您的愿望输出。