“Invalid BXL stream” in MS-SQL server while execut

2020-04-18 06:25发布

I am executing an R script as ms-sql stored procedure. I'm trying to use the "geosphere" package, however when I execute the stored procedure, I'm getting the error "Invalid BXL stream" and the execution halts. The package is already installed on the machine and simply loading the package causes this error i.e library("geosphere") causes the error.

I can however, use this package independently with R Studio, so there doesn't seem to be any issue with the package.

2条回答
别忘想泡老子
2楼-- · 2020-04-18 06:40

Had a similar issue today but with a different package. Getting "invalid BXL stream from MSSQL stored procedure. However, i found that If i opened up Rterm.exe and typed the command 'require(packagename)' then Rterm crashes with "Rterm frontend has stopped working". This looks like a memory issue - which has also been suggested causes the "invalid BXL stream" error. However, my issue turned out to be the fact that the dependencies for the packages had not been installed correctly (perhaps you are working through a proxy?). I basically removed all the library packages that had been created when I first installed the problem package and did a install.packages("packagename"). All started working!

Apologies - just noticed that you stated that the package worked independently with R studio - this is probably an issue with R Memory allocation with SQL - See http://henkvandervalk.com/introducing-microsoft-sql-server-2016-r-services

查看更多
仙女界的扛把子
3楼-- · 2020-04-18 06:51

I know this question is dated but I've run into the same issue multiple times so I wanted to leave my results here.

What I've found in using sp_execute_external_script to run R and Python scripts in MS-SQL 2016/17 is that the BXL error comes for 2 different reasons

  1. Bad data types - Often, SQL doesn't understand the data types being sent out of the script. Usually explicitly casting the data as a certain datatype helps here.

  2. Bad package configuration - Certain packages in the R and Anaconda distributions don't sync well with the stored procedure since the database blocks certain dependencies in these packages. Try reinstalling the package in the SQL installed instance of R or Python.

It seems that your problem falls in the latter category. I hope that helped!

查看更多
登录 后发表回答