> 데이터 베이스 > MySQL 튜토리얼 > C#에서 저장 프로시저 반환 값을 올바르게 검색하는 방법은 무엇입니까?

C#에서 저장 프로시저 반환 값을 올바르게 검색하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2025-01-05 20:19:45
원래의
247명이 탐색했습니다.

How to Properly Retrieve Stored Procedure Return Values in C#?

C#에서 저장 프로시저 반환 값 검색

다음 저장 프로시저를 고려하세요.

ALTER PROCEDURE [dbo].[Validate]
@a varchar(50),
@b varchar(50) output
AS
SET @Password = 
(SELECT Password
FROM dbo.tblUser
WHERE Login = @a)
RETURN @b
GO
로그인 후 복사

이 프로시저는 성공적으로 컴파일됩니다. . 이 쿼리를 실행하고 반환 값을 얻으려면 다음과 유사한 코드를 작성할 수 있습니다.

using System.Data.SqlClient;
using System.Configuration;

...

SqlConnection SqlConn = new SqlConnection(
    ConfigurationManager.ConnectionStrings["MyLocalSQLServer"].ConnectionString.ToString());
System.Data.SqlClient.SqlCommand sqlcomm = new System.Data.SqlClient.SqlCommand("Validate", SqlConn);

string returnValue = string.Empty;
SqlConn.Open();

sqlcomm.CommandType = CommandType.StoredProcedure;
SqlParameter param = new SqlParameter("@a", SqlDbType.VarChar);
param.Direction = ParameterDirection.Input;
param.Value = Username;
sqlcomm.Parameters.Add(param);

SqlParameter retval = sqlcomm.Parameters.Add("@b", SqlDbType.VarChar);
retval.Direction = ParameterDirection.ReturnValue;

sqlcomm.ExecuteNonQuery(); // MISSING
string retunvalue = (string)sqlcomm.Parameters["@b"].Value;
로그인 후 복사

간결함을 위해 예외 처리가 생략되었습니다. 코드의 마지막 줄을 실행하면 'null'이 반환됩니다. 이 문제를 해결하려면 쿼리 실행을 잊어버렸습니다. sqlcomm.ExecuteNonQuery()를 추가합니다. 반환 값을 검색하기 전에 아래와 같이 수행합니다.

using System.Data.SqlClient;
using System.Configuration;

...

SqlConnection SqlConn = new SqlConnection(
    ConfigurationManager.ConnectionStrings["MyLocalSQLServer"].ConnectionString.ToString());
System.Data.SqlClient.SqlCommand sqlcomm = new System.Data.SqlClient.SqlCommand("Validate", SqlConn);

string returnValue = string.Empty;
SqlConn.Open();

sqlcomm.CommandType = CommandType.StoredProcedure;
SqlParameter param = new SqlParameter("@a", SqlDbType.VarChar);
param.Direction = ParameterDirection.Input;
param.Value = Username;
sqlcomm.Parameters.Add(param);

SqlParameter retval = sqlcomm.Parameters.Add("@b", SqlDbType.VarChar);
retval.Direction = ParameterDirection.ReturnValue;

sqlcomm.ExecuteNonQuery();  // Include this line to execute the query

string retunvalue = (string)sqlcomm.Parameters["@b"].Value;
로그인 후 복사

이 변경 사항을 통합하면 저장 프로시저에서 반환 값을 성공적으로 검색할 수 있습니다.

위 내용은 C#에서 저장 프로시저 반환 값을 올바르게 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿