[학습 노트] C# 저장 프로세스 전송 매개 변수를 실행하고 output 매개 변수와return 을 되돌려줍니다value 방법
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: fangpan
-- Create date: 2012-2-1
-- Description: <Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[ECSS30_Stat]
@BeginTime DATETIME,
@EndTime DATETIME,
@Count int OUTPUT
AS
BEGIN
SET NOCOUNT ON;
--1.
IF OBJECT_ID('TEMPDB..#TEMP_FANGPAN')IS NOT NULL
DROP TABLE #TEMP_FANGPAN
CREATE TABLE #TEMP_FANGPAN(
[UserContent] [varchar](256),
[RecTime] [datetime],
[RecResult] [char](1),
[RecResultCode] [varchar](32),
[RecResultDesc] [varchar](256),
[SubRecType] [varchar](16),
[RecBizName] [varchar](32),
[RecOperationName] [varchar](16)
)
--2.
INSERT INTO #TEMP_FANGPAN(
[UserContent],
[RecTime],
[RecResult],
[RecResultCode],
[RecResultDesc],
[SubRecType],
[RecBizName],
[RecOperationName]
)
select a.[UserContent],
a.[RecTime],
a.[RecResult],
a.[RecResultCode],
a.[RecResultDesc],
a.[SubRecType],
a.[RecBizName],
a.[RecOperationName]
from dbo.LogRec_Route a
where [RecResult]='0'
--3.
select @Count=COUNT(*) FROM #TEMP_FANGPAN
where [RecTime]>=@BeginTime
and [RecTime]<=@EndTime
and [RecResultCode]='RouteResult_Items_IsNull'
IF @Count!=0
RETURN 1
ELSE
RETURN 0
END
2. 스토리지 프로세스 실행
using System;
using System.Collections.Generic;
using System.Text;
using System.Data.SqlClient;
using System.Data;
using System.Collections;
namespace READDATA
{
class Program
{
static void Main(string[] args)
{
SqlConnection conn = new SqlConnection("User ID=sa;Initial Catalog=ECSS20_logtest_AHMobile;Data Source=192.168.85.76;Password=ctitest");
conn.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "ECSS30_Stat";
cmd.CommandType = CommandType.StoredProcedure;
IDataParameter[] parameters={
new SqlParameter("@BeginTime",SqlDbType.DateTime),
new SqlParameter("@EndTime",SqlDbType.DateTime),
new SqlParameter("@Count",SqlDbType.Int),
new SqlParameter("return_value",SqlDbType.Int)
};
parameters[0].Value = "2011-01-01";
parameters[1].Value = "2012-02-01";
parameters[2].Direction = ParameterDirection.Output;
parameters[3].Direction = ParameterDirection.ReturnValue;
cmd.Parameters.AddRange(parameters);
cmd.ExecuteNonQuery();
conn.Close();
Console.WriteLine("@Count:" + parameters[2].Value);
Console.WriteLine("return_value:" + parameters[3].Value);
Console.ReadKey();
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
WebView2를 Visual Studio 2017 Express에서 사용할 수 있을 때까지Evergreen .Net Framework SDK 4.8 VisualStudio2017에서 NuGet을 사용하기 때문에 패키지 관리 방법을 packages.config 대신 PackageReference를 사용해야...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.