Postgres driver
Source:R/PqDriver.R
, R/dbConnect_PqDriver.R
, R/dbDisconnect_PqConnection.R
Postgres.Rd
DBI::dbConnect()
establishes a connection to a database.
Set drv = Postgres()
to connect to a PostgreSQL(-ish) database. Use drv = Redshift()
instead to connect to an AWS Redshift cluster.
Manually disconnecting a connection is not necessary with RPostgres, but still recommended; if you delete the object containing the connection, it will be automatically disconnected during the next GC with a warning.
Usage
Postgres()
# S4 method for class 'PqDriver'
dbConnect(
drv,
dbname = NULL,
host = NULL,
port = NULL,
password = NULL,
user = NULL,
service = NULL,
...,
bigint = c("integer64", "integer", "numeric", "character"),
check_interrupts = FALSE,
timezone = "UTC",
timezone_out = NULL
)
# S4 method for class 'PqConnection'
dbDisconnect(conn, ...)
Arguments
- drv
DBI::DBIDriver. Use
Postgres()
to connect to a PostgreSQL(-ish) database orRedshift()
to connect to an AWS Redshift cluster. Use an existing DBI::DBIConnection object to clone an existing connection.- dbname
Database name. If
NULL
, defaults to the user name. Note that this argument can only contain the database name, it will not be parsed as a connection string (internally,expand_dbname
is set tofalse
in the call toPQconnectdbParams()
).- host, port
Host and port. If
NULL
, will be retrieved fromPGHOST
andPGPORT
env vars.- user, password
User name and password. If
NULL
, will be retrieved fromPGUSER
andPGPASSWORD
envvars, or from the appropriate line in~/.pgpass
. See https://www.postgresql.org/docs/current/libpq-pgpass.html for more details.- service
Name of service to connect as. If
NULL
, will be ignored. Otherwise, connection parameters will be loaded from the pg_service.conf file and used. See https://www.postgresql.org/docs/current/libpq-pgservice.html for details on this file and syntax.- ...
Other name-value pairs that describe additional connection options as described at https://www.postgresql.org/docs/current/libpq-connect.html#LIBPQ-PARAMKEYWORDS
- bigint
The R type that 64-bit integer types should be mapped to, default is bit64::integer64, which allows the full range of 64 bit integers.
- check_interrupts
Should user interrupts be checked during the query execution (before first row of data is available)? Setting to
TRUE
allows interruption of queries running too long.- timezone
Sets the timezone for the connection. The default is
"UTC"
. IfNULL
then no timezone is set, which defaults to the server's time zone.- timezone_out
The time zone returned to R, defaults to
timezone
. If you want to display datetime values in the local timezone, set toSys.timezone()
or""
. This setting does not change the time values returned, only their display.- conn
Connection to disconnect.
Examples
library(DBI)
# Pass more arguments as necessary to dbConnect()
con <- dbConnect(RPostgres::Postgres())
dbDisconnect(con)