當前位置:首頁 » 服務存儲 » 存儲過程返回值
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

存儲過程返回值

發布時間: 2022-01-18 04:00:41

『壹』 oracle 中運行存儲過程作為返回值

oracle可以使用out型參數返回值,例如:

sql">--查詢某商品編號是否存在,返回查詢狀態
createorreplaceprocereproc_getGood
(
param_shopIdnumber,--商品編號
param_flagoutnumber--查詢狀態0不存在
)
as
declarev_countnumber(1);
begin
selectcount(*)intov_countfromtb_goodswhereshopid=param_shopid;

ifv_count=0then
param_flag:=0;
else
param_flag:=1;
endif;

end;

『貳』 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的位置(不建議)

『叄』 如何獲取存儲過程返回值

樓主會在c#中使用存儲過程嗎?
如果會的話,sql執行函數賦值給一個變數就可以了
sqlconnection
cnn
=
new
sqlconnection();
cnn.connectionstring
=
"data
source
=
數據源;uid=sa;pwd
=
;database=資料庫名";
cnn.open();//資料庫連接
//設置存儲過程參數
sqlparameter
prm;
sqlcommand
cmd
=
new
sqlcommand();
cmd.connection
=
cnn;
cmd.commandtype
=
commandtype.storedprocere;
cmd.commandtext
=
"存儲過程名";
//項目類型
prm
=
new
sqlparameter();
prm.parametername
=
"參數名1";
prm.sqldbtype
=
sqldbtype.varchar;
prm.size
=
50;
prm.value
=
combobox1.text;
prm.direction
=
parameterdirection.input;
cmd.parameters.add(prm);
...
//可以繼續設置參數,參數個數由存儲過程的具體內容決定
cmd.executenonquery();//執行存儲過程
實際上如果要獲取存儲過程的返回值,只要將上面一句代碼修改成:
int
retn
=
cmd.executenonquery();
就可以了

『肆』 存儲過程裡面執行存儲過程 並且返回值 怎麼寫

以下是我寫的存儲過程,希望在更新後的列表增加一列返回值,更新的owner,email信息若成功,返回sucess,失敗則failer,請高手幫助。USE [Test]GOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOALTER PROCEDURE [dbo].[USP_ZJ_Dim]ASSET NOCOUNT ON;BEGINdeclare @StructureType nvarchar(255)declare @CatecodeID nvarchar(255)declare @StructureCode nvarchar(255)declare @Owner nvarchar(255)declare @Email nvarchar(255)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 Fetch next from ZJ_dim into @StructureType,@CatecodeID,@StructureCode,@Owner,@Email End Close ZJ_Dim End

『伍』 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

『陸』 存儲過程返回值

create procere InsertNull
@TableName varchar(50),
@Result int output
AS
declare @dtName varchar(1000)
set @dtName='insert into ' + @TableName +' default values'
exec(@dtName)
set @Result=SCOPE_IDENTITY()
select @Result As Result --注意,這里顯示出來
go

然後exec insertnull ...參數
就相當於select Result

如果在程序里,執行這句之後,就能訪問Result欄位了

『柒』 SQL 取存儲過程的返回值

存儲過程應該有返回值的,
問題應該出現在你vb6的調用語句中(第二個參數是輸出類型的參數,
是否有正確設置).
你可以在查詢分析器中執行此存儲過程,
看看返回的結果.
還有,
此存儲過程中的select語句最好加上top
1限制,
因為你只要判斷是否能選到結果而已:
select
top
1
*
from
tb_package
where
packagenumber=@a

『捌』 獲取存儲過程返回值

這個test(100,200)這個不對的吧,其中有一個是output的值,你這個都變成input了。
還有我估計參數2是輸出參數,以為存儲過程中需要把 輸出的寫在輸入之後。
創建存儲過程語法基本如下:
create or replace procere test1( 參數1 in varchar2(20),參數 2 out varchar2(20))
還有一種可能就是如果你這兩個參數既能輸入也能輸出的話,是
create or replace procere test1( 參數1 in out varchar2(20),參數 2 in out varchar2(20))
這樣就分不清楚哪個是輸出了。

你是不是java程序組的,負責把BI組編的存儲過程放進去?
這樣需要多溝通了吧,我對java不是很了解,希望我說的sql方面的能幫到你。

『玖』 java怎麼得到存儲過程的返回值

create procere sp_compute
as
v_goods goods%ROWTYPE;
select goodsQuantity,memberId from goods
INTO v_goods
where goodsQuantity>10 order by memberId compute sum(goodsQuantity) by memberId

v_goods裡面就是你要的值。這個和JAVA沒關系,
另,我這種寫法是oracle的procere的寫法,不確定是否在你上面可以運行。
或者你可以使用sql function獲得返回值。

『拾』 帶返回值的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