https://github.com/machow/dbpath
R library for for connecting to databases via URL.
https://github.com/machow/dbpath
Last synced: 3 days ago
JSON representation
R library for for connecting to databases via URL.
- Host: GitHub
- URL: https://github.com/machow/dbpath
- Owner: machow
- License: other
- Created: 2020-12-29T20:01:26.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2022-12-20T20:26:29.000Z (about 2 years ago)
- Last Synced: 2025-02-15T15:41:35.992Z (6 days ago)
- Language: R
- Size: 80.1 KB
- Stars: 5
- Watchers: 3
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - machow/dbpath - R library for for connecting to databases via URL. (R)
README
---
output: github_document
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```# dbpath
[data:image/s3,"s3://crabby-images/9116b/9116ba61b6f43e2caba51fb414b36653dd9be2ac" alt="R build status"](https://github.com/machow/dbpath/actions)
dbpath is an R library for creating database connections via a single string (url).
## Install
```{r eval = FALSE}
remotes::install_github("machow/dbpath")
```## Examples
```{r}
library(dbpath)sql_url <- dbpath("postgresql+RPostgres://some_user:some_password@localhost:5432")
sql_url
```You can use the `dbpath` output with either DBI::dbConnect, or dplyr::tbl to create a remote connection.
```{r eval = FALSE}
# get a database connection
con <- DBI::dbConnect(sql_url)# get a database table called mtcars
tbl_mtcars <- dplyr::tbl(sql_url, "mtcars")
tbl_mtcars
```## URL Format
`dbpath` URLs follow the format below.
```
+://:@:/
```Here's an example using mysql:
```{r}
mysql_url <- "mysql+RMariaDB://root:some_password@localhost"
```In this case, we're connecting to the mysql dialect, using R's MariaDB package as a driver.
The code below shows how it translates to making the connection manually.
```{r eval = FALSE}
# dbpath
DBI::dbConnect(dbpath(mysql_url))# manual
DBI::dbConnect(
RMariaDB::MariaDB(),
user = "root",
password = "some_password",
host = "localhost"
)
```Behind the scenes, `dbpath` uses driver hooks to know that if RMariaDB is the driver, then we need its MariaDB() object.
Note that the `RMariaDB` in `mysql+RMariaDB` is optional!## Interoperability with Python
`dbpath's` approach is based on python's SQLAlchemy library.
This means that you can use the same string across languages!
R
python
```{r}
# one string to rule them all
sql_url = "postgresql://user:password@localhost:port/dbname"```
```{r eval = FALSE}
library(dbpath)
DBI::dbconnection(dbpath(sql_url))
```
```python
import sqlalchemy
sqlalchemy.create_engine(sql_url)
```
## Configuring Driver Selection
The code below adds a custom driver for SQLite.
```{r}
library(dbpath)driver_registry$set(my_driver = function () RSQLite::SQLite)
# Note the 3 slashes, rather than two, meaning no user name, password, or host
sqlite_url <- dbpath("sqlite+my_driver:///:memory:")sqlite_url
DBI::dbConnect(sqlite_url)
```### Available Driver Hooks
```{r eval = FALSE}
# see available drivers
driver_registry$get()# see defaults for when no driver is specified
driver_defaults$get()
```Here are the current driver defaults:
```
postgresql mysql mariadb
"RPostgres" "RMariaDB" "RMariaDB"
```## Configuring Driver Connections
dbpath uses an s3 method called `dbpath_params` to get a list of parameters to pass to `DBI::dbConnect` (or `dplyr::tbl`).
```{r}
url <- dbpath("postgresql://a_user:a_password@localhost/dbname")dbpath_params(url)
``````
$drv$user
[1] "a_user"$password
[1] "a_password"$host
[1] "localhost"$port
[1] ""$dbname
[1] "dbname"
```In order to support a new driver type, you can register an s3 method for it.
The function should return a list of parameters, whose names are the arguments
that would be passed to DBI::dbConnect.```{r}
dbpath_params.PqDriver <- function(driver, url) {
list(
drv = driver,
user = url$user,
password = url$password,
host = url$host,
port = url$port,
# use PqDriver specific argument: dbname
dbname = url$database
)
}
```You can get a specific drivers parameters by passing it as the first argument to `dbpath_params`:
```{r}
driver <- RPostgres::Postgres()
class(driver) #dbpath_params(driver, url)
```