StoredProcedure: Procedimento Armazenado do SQL Server: Gerador de Classe
StoredProcedure
: gera um Objeto de procedimento armazenado do SQLServer e, opcionalmente, um arquivo .sql que contém uma consulta para criar um procedimento armazenado. O StoredProcedure$registrationVec contém cadeias de caracteres que representam as consultas necessárias para a criação do procedimento armazenado
Uso
StoredProcedure (func, spName, ..., filePath = NULL ,dbName = NULL,
connectionString = NULL, batchSeparator = "GO")
Argumentos
func
Uma função R válida ou um nome de cadeia de caracteres de uma função R válida: 1) Todas as variáveis das quais a função depende devem ser definidas dentro da função ou entram como parâmetros de entrada. Entre os parâmetros de entrada pode haver no máximo 1 estrutura de dados 2) A função deve retornar uma estrutura de dados, uma lista nomeada ou um valor nulo. Pode haver no máximo uma estrutura de dados dentro da lista.
spName
Uma cadeia de caracteres que especifica o nome do procedimento armazenado.
...
Os parâmetros de entrada e saída opcionais para o procedimento armazenado; devem ser objetos de classes InputData, InputParameter ou outputParameter.
filePath
Uma cadeia de caracteres que especifica um caminho para o diretório no qual criar o .sql. Se NULL, o arquivo .sql não será gerado.
dbName
Uma cadeia de caracteres que especifica o nome do banco de dados a ser usado.
connectionString
Uma cadeia de caracteres que especifica a cadeia de conexão.
batchSeparator
O separador de lote SQL desejado (relevante somente se filePath for definido)
Valor
Objeto de Procedimento Armazenado do SQL Server
Exemplos
## Not run:
############# Example 1 #############
# etl1 - reads from and write directly to the database
etl1 <- function() {
# The query to get the data
qq <- "select top 10000 ArrDelay,CRSDepTime,DayOfWeek from AirlineDemoSmall"
# The connection string
conStr <- paste("Driver={ODBC Driver 13 for SQL Server};Server=.;Database=RevoTestDB;",
"Trusted_Connection=Yes;", sep = "")
# The data source - retrieves the data from the database
dsSqls <- RxSqlServerData(sqlQuery=qq, connectionString=conStr)
# The destination data source
dsSqls2 <- RxSqlServerData(table ="cleanData", connectionString = conStr)
# A transformation function
transformFunc <- function(data) {
data$CRSDepHour <- as.integer(trunc(data$CRSDepTime))
return(data)
}
# The transformation variables
transformVars <- c("CRSDepTime")
rxDataStep(inData = dsSqls,
outFile = dsSqls2,
transformFunc=transformFunc,
transformVars=transformVars,
overwrite = TRUE)
return(NULL)
}
# Create a StoredProcedure object
sp_ds_ds <- StoredProcedure(etl1, "spTest",
filePath = ".", dbName ="RevoTestDB")
# Define a connection string
conStr <- paste("Driver={ODBC Driver 13 for SQL Server};Server=.;Database=RevoTestDB;",
"Trusted_Connection=Yes;", sep = "")
# register the stored procedure with a database
registerStoredProcedure(sp_ds_ds, conStr)
# execute the stored procedure
executeStoredProcedure(sp_ds_ds, connectionString = conStr)
############# Example 2 #############
# train 1 takes a data frame with clean data and outputs a model
train1 <- 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)
mm <- rxSerializeModel(mm)
return(list("mm" = mm))
}
# 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"))
# create an OutputParameter object for the variable inside the return list
# note: if that variable is a data frame use OutputData object
out <- 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("train1", "spTest1", id, out,
filePath = ".")
# register the stored procedure with the database
registerStoredProcedure(sp_df_op, conStr)
# get the linear model
model <- executeStoredProcedure(sp_df_op, connectionString = conStr)
mm <- rxUnserializeModel(model$params$op1)
## End(Not run)