存儲過程應該有返回值的,
問題應該出現在你vb6的調用語句中(第二個參數是輸出類型的參數,
是否有正確設置).
你可以在查詢分析器中執行此存儲過程,
看看返回的結果.
還有,
此存儲過程中的select語句最好加上top
1限制,
因為你只要判斷是否能選到結果而已:
select
top
1
*
from
tb_package
where
packagenumber=@a
2. SQL Server 在一個存儲過程中調用另外一個存儲過程獲取返回值,出現報錯
第一種方法: 使用output參數
USE AdventureWorks;
GO
IF OBJECT_ID ( 'Proction.usp_GetList', 'P' ) IS NOT NULL 
    DROP PROCEDURE Proction.usp_GetList;
GO
CREATE PROCEDURE Proction.usp_GetList @proct varchar(40) 
    , @maxprice money 
    , @compareprice money OUTPUT
    , @listprice money OUT
AS
    SELECT p.name AS Proct, p.ListPrice AS 'List Price'
    FROM Proction.Proct p
    JOIN Proction.ProctSubcategory s 
      ON p.ProctSubcategoryID = s.ProctSubcategoryID
    WHERE s.name LIKE @proct AND p.ListPrice < @maxprice;
-- Populate the output variable @listprice.
SET @listprice = (SELECT MAX(p.ListPrice)
        FROM Proction.Proct p
        JOIN  Proction.ProctSubcategory s 
          ON p.ProctSubcategoryID = s.ProctSubcategoryID
        WHERE s.name LIKE @proct AND p.ListPrice < @maxprice);
-- Populate the output variable @compareprice.
SET @compareprice = @maxprice;
GO
另一個存儲過程調用的時候:
Create Proc Test
as
DECLARE @compareprice money, @cost money 
EXECUTE Proction.usp_GetList '%Bikes%', 700, 
    @compareprice OUT, 
    @cost OUTPUT
IF @cost <= @compareprice 
BEGIN
    PRINT 'These procts can be purchased for less than 
    $'+RTRIM(CAST(@compareprice AS varchar(20)))+'.'
END
ELSE
    PRINT 'The prices for all procts in this category exceed 
    $'+ RTRIM(CAST(@compareprice AS varchar(20)))+'.'
第二種方法:創建一個臨時表
create proc GetUserName
as
begin
    select 'UserName'
end
Create table #tempTable (userName nvarchar(50))
insert into #tempTable(userName)
exec GetUserName
select #tempTable
--用完之後要把臨時表清空
drop table #tempTable--需要注意的是,這種方法不能嵌套。例如:
  procere   a   
  begin   
      ...   
      insert   #table   exec   b   
  end   
    
  procere   b   
  begin   
      ...   
      insert   #table    exec   c   
      select   *   from   #table     
  end   
    
  procere   c   
  begin   
      ...   
      select   *   from   sometable   
  end  
--這里a調b的結果集,而b中也有這樣的應用b調了c的結果集,這是不允許的,
--會報「INSERT EXEC 語句不能嵌套」錯誤。在實際應用中要避免這類應用的發生。
第三種方法:聲明一個變數,用exec(@sql)執行:
1);EXEC 執行SQL語句
declare @rsql varchar(250)
        declare @csql varchar(300)
        declare @rc nvarchar(500)
        declare @cstucount int
        declare @ccount int
        set @rsql='(select Classroom_id from EA_RoomTime where zc='+@zc+' and xq='+@xq+' and T'+@time+'=''否'') and ClassroomType=''1'''
        --exec(@rsql)
        set @csql='select @a=sum(teststucount),@b=sum(classcount) from EA_ClassRoom where classroom_id in '
        set @rc=@csql+@rsql
        exec sp_executesql @rc,N'@a int output,@b int output',@cstucount output,@ccount output--將exec的結果放入變數中的做法
        --select @csql+@rsql
        --select @cstucount
3. 取一個SQL存儲過程的返回值
當@UserID存在返回JID,否則返回-1,--存儲過程Create  Procere _GetUserJID(@UserID Varchar(128),@Rst Int Out)
As
Begin
 Select @Rst=JID From TB_USer Where StrUserID=@UserID
 If(Isnull(@Rst,0)=0)
  Set @UserID=-1
 Set @Rst=@UserID 
End
 --調用
Declare @Rst Int
Exec  _GetUserJID '1001',@Rst Out 
Select @Rst--函數Create Function  F_GetUserJID(@UserID Varchar(128))
Returns Int
As
Begin
 Declare @Rst Int
 Select @Rst=JID From TB_USer Where StrUserID=@UserID
 If @Rst Is Null
   Set @Rst=-1
 Return @Rst   
End --調用Select dbo.F_GetUserJID('1001')
4. 如何使用SQL變數獲取一個存儲過程的返回值
createprocStuProc
@snamevarchar(100),
@IsRightintoutput//傳出參數
as
ifexists(selectS#,Sname,Sage,Ssexfromstudentwheresname=@sname)
set@IsRight=1
else
set@IsRight=0
go
declare@IsRightint
execStuProc'趙雷',@IsRightoutput
select@IsRight
5. sql server 2008存儲過程執行返回值-6是什麼意思
存儲過程返回的值是自己寫存儲過程就定義好的,返回的-6具體是什麼得根據存儲過程的具體功能才知道是什麼意思,  
比如說你存儲過程 只是計算兩個數據的和,那麼返回的值-6就是兩個數的和了
要解答詳細還需要更多的信息 
最好的辦法 就是 把存儲過程代碼貼出來
6. C#調用sql存儲過程插入返回值
好像有點麻煩 ~~   我是這么寫的,不知道對不對
create procere insert_country
@countrycode char(3),@country char(35)
as
begin
if (exists(select * from dbo.Country where cCountryCode=@countrycode))
  insert into dbo.Country([cCountryCode],[cCountry]) values(@countrycode,@country) 
end
調用如下:
private void btnInsert_Click(object sender, EventArgs e)
        {
            SqlConnection con = new SqlConnection();
            con.ConnectionString = "Data Source=(local);Initial Catalog=HR;Integrated Security=True";
            try
            {
                SqlCommand cmd = new SqlCommand("exec insert_country @countrycode=@a,@country=@b",con);
                SqlParameter sp1 = new SqlParameter("@a",@countrycode的值); 
                SqlParameter sp2 = new SqlParameter("@b",@country的值); 
                cmd.Parameters.AddRange(sq1,sq2)
                con.Open();
                int result = cmd.ExecuteNonQuery();
                con.Close();
                if (result > 0)
                {
                    MessageBox.Show("添加成功");
                }
                else
                {
                    MessageBox.Show("添加失敗");
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
7. SQL存儲過程返回值問題
USE [Test]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
---------1
alter tablle dbo.Dim_Structure add updateSTATUS varchar(6) 
go
---------1
ALTER PROCEDURE [dbo].[USP_ZJ_Dim]
AS
SET NOCOUNT ON;
BEGIN
declare @StructureType nvarchar(255)
declare @CatecodeID nvarchar(255)
declare @StructureCode nvarchar(255)
declare @Owner nvarchar(255)
declare @Email nvarchar(255)
---------------0
declare ZJ_dim cursor for 
    select [StructureType],[CatecodeID],[StructureCode],[Owner],[Email]
    from test.dbo.lander
      Open ZJ_Dim
        Fetch next from ZJ_dim into @StructureType,@CatecodeID,@StructureCode,@Owner,@Email
          While @@FETCH_STATUS=0
           Begin
            Update dbo.Dim_Structure
            Set Owner =@Owner,Email=@Email
            where StructureType=@StructureType and CatecodeID=@CatecodeID and StructureCode=@StructureCode
--------------------2
if @@rowcount>0
update dbo.Dim_Structure set updateSTATUS='sucess' where StructureType=@StructureType and CatecodeID=@CatecodeID and StructureCode=@StructureCode
else
update dbo.Dim_Structure set updateSTATUS='failer' where StructureType=@StructureType and CatecodeID=@CatecodeID and StructureCode=@StructureCode
--------------------2
           Fetch next from ZJ_dim into @StructureType,@CatecodeID,@StructureCode,@Owner,@Email
           End
 Close ZJ_Dim  
-----------3
deallocate ZJ_Dim 
------------3
 End
--1添加新列,如果有updateSTATUS欄位就不用添加了,把我代碼里的updateSTATUS換成已有欄位名
--2我添加的代碼 
--3建議注銷游標,游標不注銷太耗費內存 
--0可將1寫道0的位置(不建議)
8. 在 sql select 語句中 如何獲取 存儲過程的返回值
SQL Server中存儲過程的返回值不是通過return語句返回的(return語句是在用戶自定義函數中使用的),而是通過存儲過程的參數來返回,在定義存儲過程的參數時使用關鍵字output來指定此參數是返回值。
而在調用存儲過程時,也必須使用關鍵字給接收返回值的變數,這樣才能在調用時獲得存儲過程的返回值。
示例:
createproceredbo.pr_add@aint,@bint,@cintoutput
as
set@c=@a+@b
go
調用:
declare@vint
executedbo.pr_add1,2,@voutput
select@v
9. SQL中存儲過程調用存儲過程,怎麼取返回值
存儲過程中的第一個參數 @title 將接收由調用程序指定的輸入值,而第二個參數 @ytd_sales 將向調用程序返回該值。SELECT 語句使用 @title 參數以獲得正確的 ytd_sales 值,並將該值賦予 @ytd_sales 輸出參數。
CREATE PROCEDURE get_sales_for_title
@title varchar(80),   -- This is the input parameter.
@ytd_sales int OUTPUT -- This is the output parameter.
AS  
-- Get the sales for the specified title and 
-- assign it to the output parameter.
SELECT @ytd_sales = ytd_sales
FROM titles
WHERE title = @title
RETURN
GO
10. 帶返回值的sql語句(存儲過程)
如果不喜歡用output參數的話,多個輸出參數可以用表格的方式輸出。
例如:
create procere proc_name 
as
begin
declare @out_para1 int, @out_para2 nvarchar(20)
set @out_para1 = 100
set @out_para2 = N'擺渡浮橋'
select @out_para1 as 成績, @out_para2 as 姓名
end
