![](/img/trans.png)
[英]Retrieve the returned value from sql server stored procedure using java
[英]Null value is returned from stored procedure
我有存儲過程返回用戶名。 我正在從java(EclipseIDE)調用存儲過程。 從存儲過程返回的值為Null。 如何避免此Null
值。
這是我的存儲過程
USE `employee`;
DROP procedure IF EXISTS `add1`;
DELIMITER $$
USE `employee`$$
CREATE DEFINER=`root`@`localhost` PROCEDURE `add1`(IN UserId int,
IN UserFirstName varchar(50),
IN UserLastName varchar(50),
IN Education varchar(50),
IN MarksInME int,
IN MarksInBE int,
IN MarksInPUC int,
IN Gender varchar(50),
OUT UserName varchar(50))
BEGIN
declare varName varchar(50);
select UserFirstName into varName from User where UserId=3516;
set UserName=varName;
insert into user(UserId,UserFirstName,UserLastName,Education,MarksInME,MarksInBE,MarksInPUC,Gender)
values(UserId,UserFirstName,UserLastName,Education,MarksInME,MarksInBE, MarksInPUC,Gender);
END$$
DELIMITER ;
我正在呼叫存儲過程:
java.sql.CallableStatement cStmt = conn.prepareCall("{call add1(?,?,?,?,?,?,?,?,?)}");
cStmt.setInt(1,3541);
cStmt.setString(2,"pALLAVI");
cStmt.setString(3,"K");
cStmt.setString(4,"BE");
cStmt.setInt(5,0);
cStmt.setInt(6,60);
cStmt.setInt(7,600);
cStmt.setString(8,"chetana@gmail.com");
cStmt.registerOutParameter(9, java.sql.Types.VARCHAR);
cStmt.execute();
userName = cStmt.getString(9);
當我嘗試打印UserName時,將其打印為Null?
UserId是硬編碼的:
select UserFirstName into varName from User where UserId=3516;
請檢查以下查詢:
call add1(3541,'pALLAVI','K','BE',0,60,600,'chetana@gmail.com',@UserName);
SELECT @UserName;
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.