4

我正在尝试使用传递给存储过程的参数在 R-Services 中运行一个简单的 R sum,但我不知道该怎么做,也找不到一个好的例子。这是我到目前为止所拥有的:

IF OBJECT_ID ( 'TEST', 'P' ) IS NOT NULL   
    DROP PROCEDURE TEST;
GO

CREATE PROCEDURE TEST @a int = 0, @b int = 0 AS
BEGIN
    EXEC sp_execute_external_script
    @language = N'R'
    ,@script = N'print(sum(@a, @b))' -- how to pass params here?
    ,@input_data_1 = N'@a'
    return @a + @b;
END

EXEC dbo.TEST @a = 2, @b = 3
GO

我的问题是如何将存储过程 ( @aand @b) 中读取的变量传递给 R 脚本?

4

3 回答 3

2

考虑使用@params将 SQL Server 参数传递给 R 变量,如本MS 文档中所示。请务必始终返回一个数据框对象并留给@input_data_1您需要传递到InputDataSet数据框对象中的 R 脚本的 SQL Server 查询(因此此处为空白)。

CREATE PROCEDURE myProc (@a int, @b int)
AS
    EXEC sp_execute_external_script    
      @language = N'R'    
    , @script = N' OutputDataSet <- data.frame(SumRes = sum(a_r, b_r));'    
    , @input_data_1 = N'   ;' 
    , @params = N' @a_r int, @b_r int'  
    , @a_r = @a
    , @b_r = @b
    WITH RESULT SETS (([SumResult] int NOT NULL)); 

然后调用程序:

EXEC dbo.myProc @a = 2, @b = 3
于 2017-06-13T00:51:09.427 回答
0

在查询下方运行

EXEC dbo.TEST 2,  3
于 2017-06-12T15:45:38.303 回答
0
Field1 <- 'fd'
Field2 <- '20'
query <- paste0(
  "exec df_test @Name = ", Field1, ", @ProductNumber = ", Field2, ""
)
sqlQuery(cn, query)
odbcClose(cn)

像这样为 r 代码执行存储过程

快乐编码... :)

于 2017-11-01T09:57:16.483 回答