I want to filter a postgres database so I can bring a subset of the data into R for analysis. I can successfully filter by a single condition (pick a single featureid) but not by a vector of values. For example, if I set up the connection to the database as such
library(dplyr)
db <- src_postgres(dbname = 'conte_dev', host = '155.0.0.x', port = '1234', user = '...', password = '...')
tbl_daymet <- tbl(db, 'daymet')
then it works if I filter to a single value
tbl_filtered <- tbl_daymet %>%
dplyr::filter(featureid == 739554)
tbl_filtered
Source: postgres 9.3.5 [[email protected]:5432/conte_dev]
From: daymet [12,410 x 9]
Filter: featureid == 739554
featureid date tmax tmin prcp dayl srad vp swe
1 739554 1980-01-18 -1.9375 -12.2500 0.000 32140.8 199.6 240 100.5
2 739554 1980-01-19 1.1250 -3.4375 0.000 32140.8 100.4 480 99.0
3 739554 1980-01-20 0.0000 -7.5000 0.000 32486.4 160.4 360 99.0
4 739554 1980-01-21 -6.5000 -15.7500 0.000 32486.4 193.6 180 99.0
5 739554 1980-01-22 -11.8125 -18.7500 0.000 32486.4 156.8 140 99.0
6 739554 1980-01-23 -6.4375 -16.5000 3.000 32832.0 157.2 160 102.5
7 739554 1980-01-24 -6.8750 -19.0000 3.125 32832.0 178.0 120 105.0
8 739554 1980-01-25 -15.0000 -23.0625 0.000 32918.4 184.4 80 105.0
9 739554 1980-01-26 -9.9375 -20.7500 0.000 33177.6 229.2 120 105.0
10 739554 1980-01-27 -7.0625 -15.9375 0.000 33177.6 202.4 165 105.0
.. ... ... ... ... ... ... ... ... ...
However if I try to filter to a group of values in featureid
catches <- c(739554, 739554)
tbl_derived_metrics <- tbl_daymet %>%
dplyr::filter(featureid %in% catches)
I get an error
Error in postgresqlExecStatement(conn, statement, ...) : RS-DBI driver: (could not Retrieve the result : ERROR: syntax error at or near "739554" LINE 3: WHERE "featureid" IN 739554 ^ ) In addition: Warning message: In postgresqlQuickSQL(conn, statement, ...) : Could not create executeSELECT count(*) FROM (SELECT "featureid", "date", "tmax", "tmin", "prcp", "dayl", "srad", "vp", "swe" FROM "daymet" WHERE "featureid" IN 739554) AS "master"
I believe this would work if it were a dataframe in R rather than a linked table in postgres. However, I need to do the filtering first since the table contains a few billion rows. Is there a special command I can use related to postgres? The current code doesn't work whether I use characters or integers.