InputParameter: Vstupní parametr pro uloženou proceduru SQL: Generátor tříd
InputParameter
: vygeneruje InputParameter Object, který zachycuje informace o vstupních parametrech funkce R, která má být vložena do uložené procedury SQL Serveru. Ty se stanou vstupními parametry uložené procedury. Podporované typy R vstupních parametrů jsou POSIXct, číselné, znakové, celočíselné, logické a nezpracované.
Zvyk
InputParameter(name, type, defaultValue = NULL, defaultQuery = NULL,
value = NULL, enableOutput = FALSE)
Argumenty
name
Řetězec znaku, název vstupního objektu parametru.
type
Znakový řetězec představující typ R vstupního objektu parametru.
defaultValue
Výchozí hodnota parametru. Nepodporuje se pro "raw".
defaultQuery
Řetězec znaku určující výchozí dotaz, který načte data, pokud jiný dotaz není k dispozici v době spuštění uložené procedury.
value
Hodnota, která se použije pro parametr v dalším spuštění uložené procedury.
enableOutput
Nastavení tohoto vstupního nebo výstupního parametru
Hodnota
InputParameter – objekt
Příklady
## Not run:
# See ?StoredProcedure for creating the `cleandata` table.
# and ?executeStoredProcedure for creating the `rdata` table.
# score1 makes a batch prediction given clean data(indata),
# model object(model_param), and the new name of the variable
# that is being predicted
score1 <- function(indata, model_param, predVarName) {
indata[,"DayOfWeek"] <- factor(indata[,"DayOfWeek"], levels=c("Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"))
# The connection string
conStr <- paste("Driver={ODBC Driver 13 for SQL Server};Server=.;Database=RevoTestDB;",
"Trusted_Connection=Yes;", sep = "")
# The compute context
computeContext <- RxInSqlServer(numTasks=4, connectionString=conStr)
mm <- rxReadObject(as.raw(model_param))
# Predict
result <- rxPredict(modelObject = mm,
data = indata,
outData = NULL,
predVarNames = predVarName,
extraVarsToWrite = c("ArrDelay"),
writeModelVars = TRUE,
overwrite = TRUE)
}
# connections string
conStr <- paste0("Driver={ODBC Driver 13 for SQL Server};Server=.;Database=RevoTestDB;",
"Trusted_Connection=Yes;")
# create InputData Object for an input parameter that is a data frame
id <- InputData(name = "indata", defaultQuery = "SELECT * from cleanData")
# InputParameter for the model_param input variable
model <- InputParameter("model_param", "raw",
defaultQuery =
"select top 1 value from rdata where [key] = 'linmod.v1'")
# InputParameter for the predVarName variable
name <- InputParameter("predVarName", "character", value = "ArrDelayEstimate")
sp_df_df <- StoredProcedure(score1, "sTest", id, model, name,
filePath = ".")
## End(Not run)