OutputParameter: Parámetro de salida para el procedimiento almacenado de SQL: Generador de clases
OutputParameter
: genera un objeto OutputParameter que captura la información sobre los parámetros de salida de la función que se va a incrustar en un procedimiento almacenado de SQL Server. Estos se convertirán en los parámetros de salida del procedimiento almacenado. Los tipos de R admitidos de los parámetros de salida son POSIXct, numeric, character, integer, logical y raw.
Este objeto debe crearse si la función de R devuelve una lista con nombre para los miembros que no son de marco de datos de la lista.
Uso
OutputParameter(name, type)
Argumentos
name
Cadena de caracteres, el nombre del objeto de parámetro de salida.
type
Tipo R del objeto de parámetro de salida.
Valor
OutputParameter (objeto)
Ejemplos
## 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)