다음을 통해 공유


OutputParameter: SQL 저장 프로시저에 대한 출력 매개 변수: 클래스 생성기

OutputParameter: SQL Server 저장 프로시저에 포함할 함수의 출력 매개 변수에 대한 정보를 캡처하는 OutputParameter 개체를 생성합니다. 저장 프로시저의 출력 매개 변수가 됩니다. 출력 매개 변수의 지원되는 R 형식은 POSIXct, 숫자, 문자, 정수, 논리 및 원시입니다. R 함수가 데이터 프레임이 아닌 멤버에 대해 명명된 목록을 반환하는 경우 이 개체를 만들어야 합니다.

사용법

  OutputParameter(name, type)

인수

name

출력 매개 변수 개체의 이름인 문자열입니다.

type

출력 매개 변수 개체의 R 형식입니다.

OutputParameter 개체

예제


 ## Not run:

 # See ?StoredProcedure for creating the "cleandata" table.

 # train 2 takes a data frame with clean data and outputs a model
 # as well as the data on the basis of which the model was built
 train2 <- function(in_df) {
 in_df[,"DayOfWeek"] <- factor(in_df[,"DayOfWeek"], levels=c("Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"))
   # The model formula
   formula <- ArrDelay ~ CRSDepTime + DayOfWeek + CRSDepHour:DayOfWeek
   # Train the model
   rxSetComputeContext("local")
   mm <- rxLinMod(formula, data=in_df, transformFunc=NULL, transformVars=NULL)
   mm <- rxSerializeModel(mm)
   return(list(mm = mm, in_df = in_df))
 }
 # create InputData Object for an input parameter that is a data frame
 # note: if the input parameter is not a data frame use InputParameter object
 id <- InputData(name = "in_df",
                 defaultQuery = paste0("select top 10000 ArrDelay,CRSDepTime,",
                                       "DayOfWeek,CRSDepHour from cleanData"))
 out1 <- OutputData("in_df")
 # create an OutputParameter object for the variable "mm" inside the return list
 out2 <- OutputParameter("mm", "raw")
 # connections string
 conStr <- paste0("Driver={ODBC Driver 13 for SQL Server};Server=.;Database=RevoTestDB;",
                  "Trusted_Connection=Yes;")
 # create the stored procedure object
 sp_df_op <- StoredProcedure(train2, "spTest2", id, out1, out2,
                         filePath = ".")
 registerStoredProcedure(sp_df_op, conStr)
 result <- executeStoredProcedure(sp_df_op, connectionString = conStr)
 # Get back the linear model.
 mm <- rxUnserializeModel(result$params$op1)
## End(Not run)