library(tidyhydat) library(dplyr) knitr::opts_chunk$set( collapse = TRUE, comment = "#>" )
The HYDAT database is a massive hydrologic data resource. The functions in this package are designed to get the most out of the HYDAT database as quickly as possible, however in the process of reformatting the data to be more useful, the package modifies the original tables. This vignette is intended to demonstrate how to access tables within the database for your own custom HYDAT analysis, should additional information be needed. This should not be necessary for the vast majority of users, and is intended only for advanced R users.
Before loading the HYDAT database, the latest version of the database must be downloaded using
hydat_download(). This is a fairly lengthy operation (the download is around 1 GB) and may require several cups of coffee worth of your time.
# we are actually going to use the test database # so the vignette can be reproducibly rebuilt without # needing to call hydat_download prev_default <- hy_set_default_db(hy_test_db())
The HYDAT database is a SQLite database, which can be accessed in R using the dplyr and dbplyr packages. This package has simplified the connection process, so all you have to do to connect to the database is use
src <- hy_src()
To list the tables, use
src_tbls() from the dplyr package.
To inspect any particular table, use the
tbl() function with the
src and the table name.
Working with SQL tables in dplyr is much like working with regular data frames, except no data is actually read from the database until necessary. Because some of these tables are large (particularly those containing the actual data), you will want to
filter() the tables before you
collect() them (the
collect() operation loads them into memory as a
tbl(src, "STN_OPERATION_SCHEDULE") %>% filter(STATION_NUMBER == "05AA008") %>% collect()
When you are finished with the database (i.e., the end of the script), it is good practice to close the connection (you may get a loud red warning if you don't!).
# set the default location back to whatever it was before tidyhydat:::hy_set_default_db(NULL)
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.