ODBC Driver for Odoo

Build 24.0.8963

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 name, email FROM res_users WHERE company_name = 'Company Inc.'")
for (row in 1:nrow(results)) {
    cat(paste("name = ", results[row,]$name, "\n"))
    cat(paste("email = ", results[row,]$email, "\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 name, email FROM res_users WHERE company_name = 'Company Inc.'", max = 1000)
while (is.data.frame(results)) {
    for (row in 1:nrow(results)) {
        cat(paste("name = ", results[row,]$name))
        cat(paste("email = ", results[row,]$email))
    }
    rows <- sqlGetResults(cnx, max = 1000)
}

Copyright (c) 2024 CData Software, Inc. - All rights reserved.
Build 24.0.8963