0

ねえ、私はストアドプロシージャの初心者です、私は次のような手順を持っています

ALTER procedure [dbo].[list_of_employee]
(
  @employee_id int
 )
 as 
begin 
select *from project_employee_rel PE
inner join employee_details E on E.employee_id=PE.employee_id
inner join project_details P on P.project_id=PE.project_id 
where PE.employee_id=@employee_id

select * from employee_details 
where employee_id=@employee_id
end 

2つの結果を別々に返します'最初のクエリが空の行またはnullを返す場合は、2番目のクエリが実行されます。それ以外の場合は、Plzが事前に感謝します。

4

2 に答える 2

1

これを試して

ALTER procedure [dbo].[list_of_employee]
(
  @employee_id int
)
as 
BEGIN
  DECLARE @Count int
  SET @Count = select COUNT(PRIMARYKEY COLUMN) from project_employee_rel PE
    inner join employee_details E on E.employee_id=PE.employee_id
    inner join project_details P on P.project_id=PE.project_id 
    where PE.employee_id=@employee_id
  IF (@Count>0)
   BEGIN
      select *from project_employee_rel PE
       inner join employee_details E on E.employee_id=PE.employee_id
       inner join project_details P on P.project_id=PE.project_id 
       where PE.employee_id=@employee_id
   END

  ELSE
   BEGIN
       select * from employee_details 
       where employee_id=@employee_id
   END
END 
于 2013-02-28T11:32:22.840 に答える
0
IF Check Count of your first query
  return result set
ELSE 
  return other result set
END
于 2013-02-28T11:28:05.653 に答える