Querying Data
After Connecting, you can execute a SQL statement and retrieve the results.
SELECT Procedure
You can use the sqlQuery function to execute queries. By default, it will return all the results as a single data frame. This works well for smaller result sets.
results <- sqlQuery(cnx, "SELECT Id, ProductName FROM [DemoDB].[PUBLIC].Products WHERE ProductName = 'Konbu'") for (row in 1:nrow(results)) { cat(paste("Id = ", results[row,]$Id, "\n")) cat(paste("ProductName = ", results[row,]$ProductName, "\n")) }
Iterating over the Results
For larger result sets, sqlQuery can return results in batches instead of storing the entire result set in memory. When there are no results left, or an error occurs, sqlQuery and sqlGetResults will return an integer error code instead of a data frame.
results <- sqlQuery(cnx, "SELECT Id, ProductName FROM [DemoDB].[PUBLIC].Products WHERE ProductName = 'Konbu'", max = 1000) while (is.data.frame(results)) { for (row in 1:nrow(results)) { cat(paste("Id = ", results[row,]$Id)) cat(paste("ProductName = ", results[row,]$ProductName)) } rows <- sqlGetResults(cnx, max = 1000) }