Title: | Relational Data Models |
---|---|
Description: | Provides tools for working with multiple related tables, stored as data frames or in a relational database. Multiple tables (data and metadata) are stored in a compound object, which can then be manipulated with a pipe-friendly syntax. |
Authors: | Tobias Schieferdecker [aut], Kirill Müller [aut, cre] , Antoine Fabri [ctb], Darko Bergant [aut], Katharina Brunner [ctb], James Wondrasek [ctb], Indrajeet Patil [ctb] , Maëlle Salmon [ctb] , energie360° AG [fnd], cynkra GmbH [fnd, cph] |
Maintainer: | Kirill Müller <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.0.11.9015 |
Built: | 2025-01-03 01:20:16 UTC |
Source: | https://github.com/cynkra/dm |
check_key()
accepts a data frame and, optionally, columns.
It throws an error
if the specified columns are NOT a unique key of the data frame.
If the columns given in the ellipsis ARE a key, the data frame itself is returned silently, so that it can be used for piping.
check_key(x, ..., .data = deprecated())
check_key(x, ..., .data = deprecated())
x |
The data frame whose columns should be tested for key properties. |
... |
The names of the columns to be checked, processed with
|
.data |
Deprecated. |
Returns x
, invisibly, if the check is passed.
Otherwise an error is thrown and the reason for it is explained.
data <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) # this is failing: try(check_key(data, a, b)) # this is passing: check_key(data, a, c) check_key(data)
data <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) # this is failing: try(check_key(data, a, b)) # this is passing: check_key(data, a, c) check_key(data)
check_set_equality()
is a wrapper of check_subset()
.
It tests if one table is a subset of another and vice versa, i.e., if both sets are the same. If not, it throws an error.
check_set_equality( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL )
check_set_equality( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL )
x , y
|
A data frame or lazy table. |
... |
These dots are for future extensions and must be empty. |
x_select , y_select
|
Key columns to restrict the check, processed with
|
by_position |
Set to |
Returns x
, invisibly, if the check is passed.
Otherwise an error is thrown and the reason for it is explained.
data_1 <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) data_2 <- tibble::tibble(a = c(1, 2, 3), b = c(4, 5, 6), c = c(7, 8, 9)) # this is failing: try(check_set_equality(data_1, data_2, x_select = a, y_select = a)) data_3 <- tibble::tibble(a = c(2, 1, 2), b = c(4, 5, 6), c = c(7, 8, 9)) # this is passing: check_set_equality(data_1, data_3, x_select = a, y_select = a) # this is still failing: try(check_set_equality(data_2, data_3))
data_1 <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) data_2 <- tibble::tibble(a = c(1, 2, 3), b = c(4, 5, 6), c = c(7, 8, 9)) # this is failing: try(check_set_equality(data_1, data_2, x_select = a, y_select = a)) data_3 <- tibble::tibble(a = c(2, 1, 2), b = c(4, 5, 6), c = c(7, 8, 9)) # this is passing: check_set_equality(data_1, data_3, x_select = a, y_select = a) # this is still failing: try(check_set_equality(data_2, data_3))
check_subset()
tests if x
is a subset of y
.
For convenience, the x_select
and y_select
arguments allow restricting the check
to a set of key columns without affecting the return value.
check_subset(x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL)
check_subset(x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL)
x , y
|
A data frame or lazy table. |
... |
These dots are for future extensions and must be empty. |
x_select , y_select
|
Key columns to restrict the check, processed with
|
by_position |
Set to |
Returns x
, invisibly, if the check is passed.
Otherwise an error is thrown and the reason for it is explained.
data_1 <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) data_2 <- tibble::tibble(a = c(1, 2, 3), b = c(4, 5, 6), c = c(7, 8, 9)) # this is passing: check_subset(data_1, data_2, x_select = a, y_select = a) # this is failing: try(check_subset(data_2, data_1))
data_1 <- tibble::tibble(a = c(1, 2, 1), b = c(1, 4, 1), c = c(5, 6, 7)) data_2 <- tibble::tibble(a = c(1, 2, 3), b = c(4, 5, 6), c = c(7, 8, 9)) # this is passing: check_subset(data_1, data_2, x_select = a, y_select = a) # this is failing: try(check_subset(data_2, data_1))
copy_dm_to()
takes a dplyr::src_dbi
object or a DBI::DBIConnection
object as its first argument
and a dm
object as its second argument.
The latter is copied to the former.
The default is to create temporary tables, set temporary = FALSE
to create permanent tables.
Unless set_key_constraints
is FALSE
, primary key constraints are set on all databases,
and in addition foreign key constraints are set on MSSQL and Postgres/Redshift databases.
copy_dm_to( dest, dm, ..., set_key_constraints = TRUE, table_names = NULL, temporary = TRUE, schema = NULL, progress = NA, unique_table_names = NULL, copy_to = NULL )
copy_dm_to( dest, dm, ..., set_key_constraints = TRUE, table_names = NULL, temporary = TRUE, schema = NULL, progress = NA, unique_table_names = NULL, copy_to = NULL )
dest |
An object of class |
dm |
A |
... |
These dots are for future extensions and must be empty. |
set_key_constraints |
If |
table_names |
Desired names for the tables on If left
If a function or one-sided formula, Use a variant of
If a named character vector,
the names of this vector need to correspond to the table names in the Use qualified names corresponding to your database's syntax to specify e.g. database and schema for your tables. |
temporary |
If |
schema |
Name of schema to copy the Not all DBMS are supported. |
progress |
Whether to display a progress bar, if |
unique_table_names , copy_to
|
Must be |
A dm
object on the given src
with the same table names
as the input dm
.
con <- DBI::dbConnect(RSQLite::SQLite()) # Copy to temporary tables, unique table names by default: temp_dm <- copy_dm_to( con, dm_nycflights13(), set_key_constraints = FALSE ) # Persist, explicitly specify table names: persistent_dm <- copy_dm_to( con, dm_nycflights13(), temporary = FALSE, table_names = ~ paste0("flights_", .x) ) dbplyr::remote_name(persistent_dm$planes) DBI::dbDisconnect(con)
con <- DBI::dbConnect(RSQLite::SQLite()) # Copy to temporary tables, unique table names by default: temp_dm <- copy_dm_to( con, dm_nycflights13(), set_key_constraints = FALSE ) # Persist, explicitly specify table names: persistent_dm <- copy_dm_to( con, dm_nycflights13(), temporary = FALSE, table_names = ~ paste0("flights_", .x) ) dbplyr::remote_name(persistent_dm$planes) DBI::dbDisconnect(con)
db_schema_create()
creates a schema on the database.
db_schema_create(con, schema, ...)
db_schema_create(con, schema, ...)
con |
An object of class |
schema |
Class |
... |
Passed on to the individual methods. |
Methods are not available for all DBMS.
An error is thrown if a schema of that name already exists.
The argument schema
(and dbname
for MSSQL) can be provided as SQL
objects.
Keep in mind, that in this case it is assumed that they are already correctly quoted as identifiers
using DBI::dbQuoteIdentifier()
.
Additional arguments are:
dbname
: supported for MSSQL. Create a schema in a different
database on the connected MSSQL-server; default: database addressed by con
.
NULL
invisibly.
Other schema handling functions:
db_schema_drop()
,
db_schema_exists()
,
db_schema_list()
db_schema_drop()
deletes a schema from the database.
For certain DBMS it is possible to force the removal of a non-empty schema, see below.
db_schema_drop(con, schema, force = FALSE, ...)
db_schema_drop(con, schema, force = FALSE, ...)
con |
An object of class |
schema |
Class |
force |
Boolean, default |
... |
Passed on to the individual methods. |
Methods are not available for all DBMS.
An error is thrown if no schema of that name exists.
The argument schema
(and dbname
for MSSQL) can be provided as SQL
objects.
Keep in mind, that in this case it is assumed that they are already correctly quoted as identifiers.
Additional arguments are:
dbname
: supported for MSSQL. Remove a schema from a different
database on the connected MSSQL-server; default: database addressed by con
.
NULL
invisibly.
Other schema handling functions:
db_schema_create()
,
db_schema_exists()
,
db_schema_list()
db_schema_exists()
checks, if a schema exists on the database.
db_schema_exists(con, schema, ...)
db_schema_exists(con, schema, ...)
con |
An object of class |
schema |
Class |
... |
Passed on to the individual methods. |
Methods are not available for all DBMS.
Additional arguments are:
dbname
: supported for MSSQL. Check if a schema exists on a different
database on the connected MSSQL-server; default: database addressed by con
.
A boolean: TRUE
if schema exists, FALSE
otherwise.
Other schema handling functions:
db_schema_create()
,
db_schema_drop()
,
db_schema_list()
db_schema_list()
lists the available schemas on the database.
db_schema_list(con, include_default = TRUE, ...)
db_schema_list(con, include_default = TRUE, ...)
con |
An object of class |
include_default |
Boolean, if |
... |
Passed on to the individual methods. |
Methods are not available for all DBMS.
Additional arguments are:
dbname
: supported for MSSQL. List schemas on a different database on the connected MSSQL-server;
default: database addressed by con
.
A tibble with the following columns:
schema_name
the names of the schemas,
schema_owner
the schema owner names.
Other schema handling functions:
db_schema_create()
,
db_schema_drop()
,
db_schema_exists()
Perform table surgery by extracting a 'parent table' from a table, linking the original table and the new table by a key, and returning both tables.
decompose_table()
accepts a data frame, a name for the 'ID column' that will be newly created, and the names
of the columns that will be extracted into the new data frame.
It creates a 'parent table', which consists of the columns specified in the ellipsis, and a new 'ID column'. Then it removes those columns from the original table, which is now called the 'child table, and adds the 'ID column'.
decompose_table(.data, new_id_column, ...)
decompose_table(.data, new_id_column, ...)
.data |
Data frame from which columns |
new_id_column |
Name of the identifier column (primary key column) for the parent table. A column of this name is also added in 'child table'. |
... |
The columns to be extracted from the One or more unquoted expressions separated by commas. You can treat variable names as if they were positions, so you can use expressions like x:y to select ranges of variables. The arguments in ... are automatically quoted and evaluated in a context where column names represent column positions. They also support unquoting and splicing. See vignette("programming") for an introduction to those concepts. See select helpers for more details, and the examples about tidyselect helpers, such as starts_with(), everything(), ... |
A named list of length two:
entry "child_table": the child table with column new_id_column
referring to the same column in parent_table
,
entry "parent_table": the "lookup table" for child_table
.
This function is marked "experimental" because it seems more useful when applied to a table in a dm object. Changing the interface later seems harmless because these functions are most likely used interactively.
Other table surgery functions:
reunite_parent_child()
decomposed_table <- decompose_table(mtcars, new_id, am, gear, carb) decomposed_table$child_table decomposed_table$parent_table
decomposed_table <- decompose_table(mtcars, new_id, am, gear, carb) decomposed_table$child_table decomposed_table$parent_table
The dm
class holds a list of tables and their relationships.
It is inspired by datamodelr,
and extends the idea by offering operations to access the data in the tables.
dm()
creates a dm
object from tbl objects
(tibbles or lazy data objects).
new_dm()
is a low-level constructor that creates a new dm
object.
If called without arguments, it will create an empty dm
.
If called with arguments, no validation checks will be made to ascertain that
the inputs are of the expected class and internally consistent;
use dm_validate()
to double-check the returned object.
is_dm()
returns TRUE
if the input is of class dm
.
as_dm()
coerces objects to the dm
class
dm( ..., .name_repair = c("check_unique", "unique", "universal", "minimal"), .quiet = FALSE ) new_dm(tables = list()) is_dm(x) as_dm(x, ...)
dm( ..., .name_repair = c("check_unique", "unique", "universal", "minimal"), .quiet = FALSE ) new_dm(tables = list()) is_dm(x) as_dm(x, ...)
... |
Tables or existing |
.name_repair , .quiet
|
Options for name repair.
Forwarded as |
tables |
A named list of the tables (tibble-objects, not names),
to be included in the |
x |
An object. |
For dm()
, new_dm()
, as_dm()
: A dm
object.
For is_dm()
: A scalar logical, TRUE
if is this object is a dm
.
dm_from_con()
for connecting to all tables in a database
and importing the primary and foreign keys
dm_get_tables()
for returning a list of tables
dm_add_pk()
and dm_add_fk()
for adding primary and foreign keys
copy_dm_to()
for DB interaction
dm_draw()
for visualization
dm_flatten_to_tbl()
for flattening
dm_filter()
for filtering
dm_select_tbl()
for creating a dm
with only a subset of the tables
dm_nycflights13()
for creating an example dm
object
decompose_table()
for table surgery
check_key()
and check_subset()
for checking for key properties
examine_cardinality()
for checking the cardinality of the relation between two tables
dm(trees, mtcars) new_dm(list(trees = trees, mtcars = mtcars)) as_dm(list(trees = trees, mtcars = mtcars)) is_dm(dm_nycflights13()) dm_nycflights13()$airports dm_nycflights13()["airports"] dm_nycflights13()[["airports"]] dm_nycflights13() %>% names() library(dm) library(nycflights13) # using `data.frame` objects new_dm(tibble::lst(weather, airports)) # using `dm_keyed_tbl` objects dm <- dm_nycflights13() y1 <- dm$planes %>% mutate() %>% select(everything()) y2 <- dm$flights %>% left_join(dm$airlines, by = "carrier") new_dm(list("tbl1" = y1, "tbl2" = y2))
dm(trees, mtcars) new_dm(list(trees = trees, mtcars = mtcars)) as_dm(list(trees = trees, mtcars = mtcars)) is_dm(dm_nycflights13()) dm_nycflights13()$airports dm_nycflights13()["airports"] dm_nycflights13()[["airports"]] dm_nycflights13() %>% names() library(dm) library(nycflights13) # using `data.frame` objects new_dm(tibble::lst(weather, airports)) # using `dm_keyed_tbl` objects dm <- dm_nycflights13() y1 <- dm$planes %>% mutate() %>% select(everything()) y2 <- dm$flights %>% left_join(dm$airlines, by = "carrier") new_dm(list("tbl1" = y1, "tbl2" = y2))
dm_add_fk()
marks the specified columns
as the foreign key of table table
with
respect to a key of table ref_table
.
Usually the referenced columns are a primary key in ref_table
.
However, it is also possible to specify other columns via the ref_columns
argument.
If check == TRUE
, then it will first check if the values in columns
are a subset
of the values of the key in table ref_table
.
dm_add_fk( dm, table, columns, ref_table, ref_columns = NULL, ..., check = FALSE, on_delete = c("no_action", "cascade") )
dm_add_fk( dm, table, columns, ref_table, ref_columns = NULL, ..., check = FALSE, on_delete = c("no_action", "cascade") )
dm |
A |
table |
A table in the |
columns |
The columns of |
ref_table |
The table which |
ref_columns |
The column(s) of |
... |
These dots are for future extensions and must be empty. |
check |
Boolean, if |
on_delete |
Defines behavior if a row in the parent table is deleted.
- |
It is possible that a foreign key (FK) is pointing to columns that are neither primary (PK) nor explicit unique keys (UK). This can happen
when a FK is added without a corresponding PK or UK being present in the parent table
when the PK or UK is removed (dm_rm_pk()
/dm_rm_uk()
) without first removing the associated FKs.
These columns are then a so-called "implicit unique key" of the referenced table and can be listed via dm_get_all_uks()
.
An updated dm
with an additional foreign key relation.
Other foreign key functions:
dm_enum_fk_candidates()
,
dm_get_all_fks()
,
dm_rm_fk()
nycflights_dm <- dm( planes = nycflights13::planes, flights = nycflights13::flights, weather = nycflights13::weather ) nycflights_dm %>% dm_draw() # Create foreign keys: nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_fk(flights, tailnum, planes) %>% dm_add_pk(weather, c(origin, time_hour)) %>% dm_add_fk(flights, c(origin, time_hour), weather) %>% dm_draw() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_fk(flights, tailnum, planes, check = TRUE) )
nycflights_dm <- dm( planes = nycflights13::planes, flights = nycflights13::flights, weather = nycflights13::weather ) nycflights_dm %>% dm_draw() # Create foreign keys: nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_fk(flights, tailnum, planes) %>% dm_add_pk(weather, c(origin, time_hour)) %>% dm_add_fk(flights, c(origin, time_hour), weather) %>% dm_draw() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_fk(flights, tailnum, planes, check = TRUE) )
dm_add_pk()
marks the specified columns as the primary key of the specified table.
If check == TRUE
, then it will first check if
the given combination of columns is a unique key of the table.
If force == TRUE
, the function will replace an already
set key, without altering foreign keys previously pointing to that primary key.
dm_add_pk( dm, table, columns, ..., autoincrement = FALSE, check = FALSE, force = FALSE )
dm_add_pk( dm, table, columns, ..., autoincrement = FALSE, check = FALSE, force = FALSE )
There can be only one primary key per table in a dm
.
It's possible though to set an unlimited number of unique keys using dm_add_uk()
or adding foreign keys pointing to columns other than the primary key columns with dm_add_fk()
.
An updated dm
with an additional primary key.
Other primary key functions:
dm_add_uk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
nycflights_dm <- dm( planes = nycflights13::planes, airports = nycflights13::airports, weather = nycflights13::weather ) nycflights_dm %>% dm_draw() # Create primary keys: nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_pk(airports, faa, check = TRUE) %>% dm_add_pk(weather, c(origin, time_hour)) %>% dm_draw() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_pk(planes, manufacturer, check = TRUE) )
nycflights_dm <- dm( planes = nycflights13::planes, airports = nycflights13::airports, weather = nycflights13::weather ) nycflights_dm %>% dm_draw() # Create primary keys: nycflights_dm %>% dm_add_pk(planes, tailnum) %>% dm_add_pk(airports, faa, check = TRUE) %>% dm_add_pk(weather, c(origin, time_hour)) %>% dm_draw() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_pk(planes, manufacturer, check = TRUE) )
dm_add_uk()
marks the specified columns as a unique key of the specified table.
If check == TRUE
, then it will first check if
the given combination of columns is a unique key of the table.
dm_add_uk(dm, table, columns, ..., check = FALSE)
dm_add_uk(dm, table, columns, ..., check = FALSE)
dm |
A |
table |
A table in the |
columns |
Table columns, unquoted.
To define a compound key, use |
... |
These dots are for future extensions and must be empty. |
check |
Boolean, if |
The difference between a primary key (PK) and a unique key (UK) consists in the following:
When a local dm
is copied to a database (DB) with copy_dm_to()
, a PK will be set on the DB by default, whereas a UK is being ignored.
A PK can be set as an autoincrement
key (also implemented on certain DBMS when the dm
is transferred to the DB)
There can be only one PK for each table, whereas there can be unlimited UKs
A UK will be used, if the same table has an autoincrement PK in addition, to ensure that during delta load processes
on the DB (cf. dm_rows_append()
) the foreign keys are updated accordingly.
If no UK is available, the insertion is done row-wise, which also ensures a correct matching, but can be much slower.
A UK can generally enhance the data model by adding additional information
There can also be implicit UKs, when the columns addressed by a foreign key are neither a PK nor a UK.
These implicit UKs are also listed by dm_get_all_uks()
An updated dm
with an additional unqiue key.
Other primary key functions:
dm_add_pk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
nycflights_dm <- dm( planes = nycflights13::planes, airports = nycflights13::airports, weather = nycflights13::weather ) # Create unique keys: nycflights_dm %>% dm_add_uk(planes, tailnum) %>% dm_add_uk(airports, faa, check = TRUE) %>% dm_add_uk(weather, c(origin, time_hour)) %>% dm_get_all_uks() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_uk(planes, manufacturer, check = TRUE) )
nycflights_dm <- dm( planes = nycflights13::planes, airports = nycflights13::airports, weather = nycflights13::weather ) # Create unique keys: nycflights_dm %>% dm_add_uk(planes, tailnum) %>% dm_add_uk(airports, faa, check = TRUE) %>% dm_add_uk(weather, c(origin, time_hour)) %>% dm_get_all_uks() # Keys can be checked during creation: try( nycflights_dm %>% dm_add_uk(planes, manufacturer, check = TRUE) )
Emits code that assigns each table in the dm to a variable,
using pull_tbl()
with keyed = TRUE
.
These tables retain information about primary and foreign keys,
even after data transformations,
and can be converted back to a dm object with dm()
.
dm_deconstruct(dm, dm_name = NULL)
dm_deconstruct(dm, dm_name = NULL)
dm |
A |
dm_name |
The code to use to access the dm object, by default the expression passed to this function. |
This function is called for its side effect of printing generated code.
dm <- dm_nycflights13() dm_deconstruct(dm) airlines <- pull_tbl(dm, "airlines", keyed = TRUE) airports <- pull_tbl(dm, "airports", keyed = TRUE) flights <- pull_tbl(dm, "flights", keyed = TRUE) planes <- pull_tbl(dm, "planes", keyed = TRUE) weather <- pull_tbl(dm, "weather", keyed = TRUE) by_origin <- flights %>% group_by(origin) %>% summarize(mean_arr_delay = mean(arr_delay, na.rm = TRUE)) %>% ungroup() by_origin dm(airlines, airports, flights, planes, weather, by_origin) %>% dm_draw()
dm <- dm_nycflights13() dm_deconstruct(dm) airlines <- pull_tbl(dm, "airlines", keyed = TRUE) airports <- pull_tbl(dm, "airports", keyed = TRUE) flights <- pull_tbl(dm, "flights", keyed = TRUE) planes <- pull_tbl(dm, "planes", keyed = TRUE) weather <- pull_tbl(dm, "weather", keyed = TRUE) by_origin <- flights %>% group_by(origin) %>% summarize(mean_arr_delay = mean(arr_delay, na.rm = TRUE)) %>% ungroup() by_origin dm(airlines, airports, flights, planes, weather, by_origin) %>% dm_draw()
This function ensures that all columns in a dm
have unique names.
dm_disambiguate_cols( dm, .sep = ".", ..., .quiet = FALSE, .position = c("suffix", "prefix") )
dm_disambiguate_cols( dm, .sep = ".", ..., .quiet = FALSE, .position = c("suffix", "prefix") )
The function first checks if there are any column names that are not unique. If there are, those columns will be assigned new, unique, names by prefixing their existing name with the name of their table and a separator. Columns that act as primary or foreign keys will not be renamed because only the foreign key column will remain when two tables are joined, making that column name "unique" as well.
A dm
whose column names are unambiguous.
dm_nycflights13() %>% dm_disambiguate_cols()
dm_nycflights13() %>% dm_disambiguate_cols()
dm_draw()
draws a diagram, a visual representation of the data model.
dm_draw( dm, rankdir = "LR", ..., col_attr = NULL, view_type = c("keys_only", "all", "title_only"), columnArrows = TRUE, graph_attrs = "", node_attrs = "", edge_attrs = "", focus = NULL, graph_name = "Data Model", column_types = NULL, backend = "DiagrammeR", font_size = NULL )
dm_draw( dm, rankdir = "LR", ..., col_attr = NULL, view_type = c("keys_only", "all", "title_only"), columnArrows = TRUE, graph_attrs = "", node_attrs = "", edge_attrs = "", focus = NULL, graph_name = "Data Model", column_types = NULL, backend = "DiagrammeR", font_size = NULL )
dm |
A |
rankdir |
Graph attribute for direction (e.g., 'BT' = bottom –> top). |
... |
These dots are for future extensions and must be empty. |
col_attr |
Deprecated, use |
view_type |
Can be "keys_only" (default), "all" or "title_only". It defines the level of details for rendering tables (only primary and foreign keys, all columns, or no columns). |
columnArrows |
Edges from columns to columns (default: |
graph_attrs |
Additional graph attributes. |
node_attrs |
Additional node attributes. |
edge_attrs |
Additional edge attributes. |
focus |
A list of parameters for rendering (table filter). |
graph_name |
The name of the graph. |
column_types |
Set to |
backend |
Currently, only the default |
font_size |
Font size for:
Can be set as a named integer vector, e.g. |
Currently, dm uses DiagrammeR to draw diagrams.
Use DiagrammeRsvg::export_svg()
to convert the diagram to an SVG file.
The backend for drawing the diagrams might change in the future.
If you rely on DiagrammeR, pass an explicit value for the backend
argument.
An object with a print()
method, which,
when printed, produces the output seen in the viewer as a side effect.
Currently, this is an object of class grViz
(see also
DiagrammeR::grViz()
), but this is subject to change.
dm_set_colors()
for defining the table colors.
dm_set_table_description()
for adding details to one or more tables in the diagram
dm_nycflights13() %>% dm_draw() dm_nycflights13(cycle = TRUE) %>% dm_draw(view_type = "title_only") head(dm_get_available_colors()) length(dm_get_available_colors()) dm_nycflights13() %>% dm_get_colors()
dm_nycflights13() %>% dm_draw() dm_nycflights13(cycle = TRUE) %>% dm_draw(view_type = "title_only") head(dm_get_available_colors()) length(dm_get_available_colors()) dm_nycflights13() %>% dm_get_colors()
Determine which columns would be good candidates to be used as foreign keys of a table,
to reference the primary key column of another table of the dm
object.
dm_enum_fk_candidates(dm, table, ref_table, ...) enum_fk_candidates(dm_zoomed, ref_table, ...)
dm_enum_fk_candidates(dm, table, ref_table, ...) enum_fk_candidates(dm_zoomed, ref_table, ...)
dm |
A |
table |
The table whose columns should be tested for suitability as foreign keys. |
ref_table |
A table with a primary key. |
... |
These dots are for future extensions and must be empty. |
dm_zoomed |
A |
dm_enum_fk_candidates()
first checks if ref_table
has a primary key set,
if not, an error is thrown.
If ref_table
does have a primary key, then a join operation will be tried using
that key as the by
argument of join() to match it to each column of table
.
Attempting to join incompatible columns triggers an error.
The outcome of the join operation determines the value of the why
column in the result:
an empty value for a column of table
that is a suitable foreign key candidate
the count and percentage of missing matches for a column that is not suitable
the error message triggered for unsuitable candidates that may include the types of mismatched columns
enum_fk_candidates()
works like dm_enum_fk_candidates()
with the zoomed table as table
.
A tibble with the following columns:
columns
columns of table
,
candidate
boolean: are these columns a candidate for a foreign key,
why
if not a candidate for a foreign key, explanation for for this.
These functions are marked "experimental" because we are not yet sure about
the interface, in particular if we need both dm_enum...()
and enum...()
variants.
Changing the interface later seems harmless because these functions are
most likely used interactively.
Other foreign key functions:
dm_add_fk()
,
dm_get_all_fks()
,
dm_rm_fk()
dm_nycflights13() %>% dm_enum_fk_candidates(flights, airports) dm_nycflights13() %>% dm_zoom_to(flights) %>% enum_fk_candidates(airports)
dm_nycflights13() %>% dm_enum_fk_candidates(flights, airports) dm_nycflights13() %>% dm_zoom_to(flights) %>% enum_fk_candidates(airports)
This function returns a tibble with information about
the cardinality of the FK constraints.
The printing for this object is special, use tibble::as_tibble()
to print as a regular tibble.
dm_examine_cardinalities( .dm, ..., .progress = NA, dm = deprecated(), progress = deprecated() )
dm_examine_cardinalities( .dm, ..., .progress = NA, dm = deprecated(), progress = deprecated() )
.dm |
A |
... |
These dots are for future extensions and must be empty. |
.progress |
Whether to display a progress bar, if |
dm , progress
|
Uses examine_cardinality()
on each foreign key that is defined in the dm
.
A tibble with the following columns:
child_table
child table,
child_fk_cols
foreign key column(s) in child table as list of character vectors,
parent_table
parent table,
parent_key_cols
key column(s) in parent table as list of character vectors,
cardinality
the nature of cardinality along the foreign key.
Other cardinality functions:
examine_cardinality()
dm_nycflights13() %>% dm_examine_cardinalities()
dm_nycflights13() %>% dm_examine_cardinalities()
This function returns a tibble with information about
which key constraints are met (is_key = TRUE
) or violated (FALSE
).
The printing for this object is special, use tibble::as_tibble()
to print as a regular tibble.
dm_examine_constraints( .dm, ..., .progress = NA, dm = deprecated(), progress = deprecated() )
dm_examine_constraints( .dm, ..., .progress = NA, dm = deprecated(), progress = deprecated() )
.dm |
A |
... |
These dots are for future extensions and must be empty. |
.progress |
Whether to display a progress bar, if |
dm , progress
|
For the primary key constraints, it is tested if the values in the respective columns are all unique. For the foreign key constraints, the tests check if for each foreign key constraint, the values of the foreign key column form a subset of the values of the referenced column.
A tibble with the following columns:
table
the table in the dm
,
kind
"PK" or "FK",
columns
the table columns that define the key,
ref_table
for foreign keys, the referenced table,
is_key
logical,
problem
if is_key = FALSE
, the reason for that.
dm_nycflights13() %>% dm_examine_constraints()
dm_nycflights13() %>% dm_examine_constraints()
Filtering a table of a dm
object may affect other tables that are connected to it
directly or indirectly via foreign key relations.
dm_filter()
can be used to define filter conditions for tables using syntax that is similar to dplyr::filter()
.
The filters work across related tables:
The resulting dm
object only contains rows that are related
(directly or indirectly) to rows that remain after applying the filters
on all tables.
dm_filter(.dm, ...)
dm_filter(.dm, ...)
.dm |
A |
... |
Named logical predicates.
The names correspond to tables in the Multiple conditions are combined with |
As of dm 1.0.0, these conditions are no longer stored in the dm
object,
instead they are applied to all tables during the call to dm_filter()
.
Calling dm_apply_filters()
or dm_apply_filters_to_tbl()
is no longer necessary.
Use dm_zoom_to()
and dplyr::filter()
to filter rows without affecting related tables.
An updated dm
object with filters executed across all tables.
dm_nyc <- dm_nycflights13() dm_nyc %>% dm_nrow() dm_nyc_filtered <- dm_nycflights13() %>% dm_filter(airports = (name == "John F Kennedy Intl")) dm_nyc_filtered %>% dm_nrow() # If you want to keep only those rows in the parent tables # whose primary key values appear as foreign key values in # `flights`, you can set a `TRUE` filter in `flights`: dm_nyc %>% dm_filter(flights = (1 == 1)) %>% dm_nrow() # note that in this example, the only affected table is # `airports` because the departure airports in `flights` are # only the three New York airports.
dm_nyc <- dm_nycflights13() dm_nyc %>% dm_nrow() dm_nyc_filtered <- dm_nycflights13() %>% dm_filter(airports = (name == "John F Kennedy Intl")) dm_nyc_filtered %>% dm_nrow() # If you want to keep only those rows in the parent tables # whose primary key values appear as foreign key values in # `flights`, you can set a `TRUE` filter in `flights`: dm_nyc %>% dm_filter(flights = (1 == 1)) %>% dm_nrow() # note that in this example, the only affected table is # `airports` because the departure airports in `flights` are # only the three New York airports.
dm_financial()
creates an example dm
object from the tables at
https://relational.fel.cvut.cz/dataset/Financial.
The connection is established once per session,
subsequent calls return the same connection.
dm_financial_sqlite()
copies the data to a temporary SQLite database.
The data is downloaded once per session, subsequent calls return the same database.
The trans
table is excluded due to its size.
dm_financial() dm_financial_sqlite()
dm_financial() dm_financial_sqlite()
A dm
object.
dm_financial() %>% dm_draw()
dm_financial() %>% dm_draw()
dm
into a wide tabledm_flatten_to_tbl()
gathers all information of interest in one place in a wide table.
It performs a disambiguation of column names and a cascade of joins.
dm_flatten_to_tbl(dm, .start, ..., .recursive = FALSE, .join = left_join)
dm_flatten_to_tbl(dm, .start, ..., .recursive = FALSE, .join = left_join)
dm |
A |
.start |
The table from which all outgoing foreign key relations are considered when establishing a processing order for the joins. An interesting choice could be for example a fact table in a star schema. |
... |
Unquoted names of the tables to be included in addition to the |
.recursive |
Logical, defaults to |
.join |
The type of join to be performed, see |
With ...
left empty, this function will join together all the tables of your dm
object that can be reached from the .start
table, in the direction of the foreign key relations
(pointing from the child tables to the parent tables), using the foreign key relations to
determine the argument by
for the necessary joins.
The result is one table with unique column names.
Use the ...
argument if you would like to control which tables should be joined to the .start
table.
Mind that calling dm_flatten_to_tbl()
with .join = right_join
and no table order determined in the ...
argument
will not lead to a well-defined result if two or more foreign tables are to be joined to .start
.
The resulting
table would depend on the order the tables that are listed in the dm
.
Therefore, trying this will result in a warning.
Since .join = nest_join
does not make sense in this direction (LHS = child table, RHS = parent table: for valid key constraints
each nested column entry would be a tibble of one row), an error will be thrown if this method is chosen.
The difference between .recursive = FALSE
and .recursive = TRUE
is
the following (see the examples):
.recursive = FALSE
allows only one level of hierarchy
(i.e., direct neighbors to table .start
), while
.recursive = TRUE
will go through all levels of hierarchy while joining.
Additionally, these functions differ from dm_wrap_tbl()
, which always
returns a dm
object.
A single table that results from consecutively joining all affected tables to the .start
table.
dm_financial() %>% dm_select_tbl(-loans) %>% dm_flatten_to_tbl(.start = cards) dm_financial() %>% dm_select_tbl(-loans) %>% dm_flatten_to_tbl(.start = cards, .recursive = TRUE)
dm_financial() %>% dm_select_tbl(-loans) %>% dm_flatten_to_tbl(.start = cards) dm_financial() %>% dm_select_tbl(-loans) %>% dm_flatten_to_tbl(.start = cards, .recursive = TRUE)
dm_from_con()
creates a dm from some or all tables in a dplyr::src
(a database or an environment) or which are accessible via a DBI-Connection.
For Postgres/Redshift and SQL Server databases, primary and foreign keys
are imported from the database.
dm_from_con( con = NULL, table_names = NULL, learn_keys = NULL, .names = NULL, ... )
dm_from_con( con = NULL, table_names = NULL, learn_keys = NULL, .names = NULL, ... )
con |
A |
table_names |
A character vector of the names of the tables to include. |
learn_keys |
Set to |
.names |
A glue specification that describes how to name the tables
within the output, currently only for MSSQL, Postgres/Redshift and MySQL/MariaDB.
This can use |
... |
Additional parameters for the schema learning query.
|
A dm
object.
con <- dm_get_con(dm_financial()) # Avoid DBI::dbDisconnect() here, because we don't own the connection
con <- dm_get_con(dm_financial()) # Avoid DBI::dbDisconnect() here, because we don't own the connection
Get a summary of all foreign key relations in a dm
.
dm_get_all_fks(dm, parent_table = NULL, ...)
dm_get_all_fks(dm, parent_table = NULL, ...)
dm |
A |
parent_table |
One or more table names, unquoted,
to return foreign key information for.
If given, foreign keys are returned in that order.
The default |
... |
These dots are for future extensions and must be empty. |
A tibble with the following columns:
child_table
child table,
child_fk_cols
foreign key column(s) in child table as list of character vectors,
parent_table
parent table,
parent_key_cols
key column(s) in parent table as list of character vectors.
on_delete
behavior on deletion of rows in the parent table.
Other foreign key functions:
dm_add_fk()
,
dm_enum_fk_candidates()
,
dm_rm_fk()
dm_nycflights13() %>% dm_get_all_fks()
dm_nycflights13() %>% dm_get_all_fks()
dm
objectdm_get_all_pks()
checks the dm
object for primary keys and
returns the tables and the respective primary key columns.
dm_get_all_pks(dm, table = NULL, ...)
dm_get_all_pks(dm, table = NULL, ...)
dm |
A |
table |
One or more table names, unquoted,
to return primary key information for.
If given, primary keys are returned in that order.
The default |
... |
These dots are for future extensions and must be empty. |
A tibble with the following columns:
table
table name,
pk_col
column name(s) of primary key, as list of character vectors.
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
dm_nycflights13() %>% dm_get_all_pks()
dm_nycflights13() %>% dm_get_all_pks()
dm
objectdm_get_all_uks()
checks the dm
object for unique keys
(primary keys, explicit and implicit unique keys) and returns the tables and
the respective unique key columns.
dm_get_all_uks(dm, table = NULL, ...)
dm_get_all_uks(dm, table = NULL, ...)
dm |
A |
table |
One or more table names, unquoted,
to return unique key information for.
The default |
... |
These dots are for future extensions and must be empty. |
There are 3 kinds of unique keys:
PK
: Primary key, set by dm_add_pk()
explicit UK
: Unique key, set by dm_add_uk()
implicit UK
: Unique key, not explicitly set, but referenced by a foreign key.
A tibble with the following columns:
table
table name,
uk_col
column name(s) of primary key, as list of character vectors,
kind
kind of unique key, see details.
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_pks()
,
dm_has_pk()
,
dm_rm_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
dm_nycflights13() %>% dm_get_all_uks()
dm_nycflights13() %>% dm_get_all_uks()
dm_get_con()
returns the DBI connection for a dm
object.
This works only if the tables are stored on a database, otherwise an error
is thrown.
dm_get_con(dm)
dm_get_con(dm)
dm |
A |
All lazy tables in a dm object must be stored on the same database server and accessed through the same connection, because a large part of the package's functionality relies on efficient joins.
The DBI::DBIConnection
object for a dm
object.
dm_financial() %>% dm_get_con()
dm_financial() %>% dm_get_con()
dm_get_tables()
returns a named list of dplyr tbl objects
of a dm
object.
dm_get_tables(x, ..., keyed = FALSE)
dm_get_tables(x, ..., keyed = FALSE)
x |
A |
... |
These dots are for future extensions and must be empty. |
keyed |
Set to |
A named list with the tables (data frames or lazy tables)
constituting the dm
.
dm()
and new_dm()
for constructing a dm
object from tables.
dm_nycflights13() %>% dm_get_tables() dm_nycflights13() %>% dm_get_tables(keyed = TRUE) dm_nycflights13() %>% dm_get_tables(keyed = TRUE) %>% new_dm()
dm_nycflights13() %>% dm_get_tables() dm_nycflights13() %>% dm_get_tables(keyed = TRUE) dm_nycflights13() %>% dm_get_tables(keyed = TRUE) %>% new_dm()
This function starts a Shiny application that allows to define dm
objects
from a database or from local data frames.
The application generates R code that can be inserted or copy-pasted
into an R script or function.
dm_gui(..., dm = NULL, select_tables = TRUE, debug = FALSE)
dm_gui(..., dm = NULL, select_tables = TRUE, debug = FALSE)
... |
These dots are for future extensions and must be empty. |
dm |
An initial dm object, currently required. |
select_tables |
Show selectize input to select tables? |
debug |
Set to |
In a future release, the app will also allow composing dm
objects directly
from database connections or data frames.
The signature of this function is subject to change without notice. This should not pose too many problems, because it will usually be run interactively.
## Not run: dm <- dm_nycflights13(cycle = TRUE) dm_gui(dm = dm) ## End(Not run)
## Not run: dm <- dm_nycflights13(cycle = TRUE) dm_gui(dm = dm) ## End(Not run)
dm_has_pk()
checks if a given table has columns marked as its primary key.
dm_has_pk(dm, table, ...)
dm_has_pk(dm, table, ...)
dm |
A |
table |
A table in the |
... |
These dots are for future extensions and must be empty. |
A logical value: TRUE
if the given table has a primary key, FALSE
otherwise.
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_rm_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
dm_nycflights13() %>% dm_has_pk(flights) dm_nycflights13() %>% dm_has_pk(planes)
dm_nycflights13() %>% dm_has_pk(flights) dm_nycflights13() %>% dm_has_pk(planes)
dm
Updates one or more existing tables in a dm
.
For now, the column names must be identical.
This restriction may be levied optionally in the future.
dm_mutate_tbl(dm, ...)
dm_mutate_tbl(dm, ...)
dm |
A |
... |
One or more tables to update in the |
dm_nycflights13() %>% dm_mutate_tbl(flights = nycflights13::flights[1:3, ])
dm_nycflights13() %>% dm_mutate_tbl(flights = nycflights13::flights[1:3, ])
dm_nest_tbl()
converts a child table to a nested column in its parent
table.
The child table should not have children itself (i.e. it needs to be a
terminal child table).
dm_nest_tbl(dm, child_table, into = NULL)
dm_nest_tbl(dm, child_table, into = NULL)
dm |
A dm. |
child_table |
A terminal table with one parent table. |
into |
The table to nest |
dm_wrap_tbl()
, dm_unwrap_tbl()
, dm_pack_tbl()
nested_dm <- dm_nycflights13() %>% dm_select_tbl(airlines, flights) %>% dm_nest_tbl(flights) nested_dm nested_dm$airlines
nested_dm <- dm_nycflights13() %>% dm_select_tbl(airlines, flights) %>% dm_nest_tbl(flights) nested_dm nested_dm$airlines
Returns a named vector with the number of rows for each table.
dm_nrow(dm)
dm_nrow(dm)
dm |
A |
A named vector with the number of rows for each table.
dm_nycflights13() %>% dm_filter(airports = (faa %in% c("EWR", "LGA"))) %>% dm_nrow()
dm_nycflights13() %>% dm_filter(airports = (faa %in% c("EWR", "LGA"))) %>% dm_nrow()
Creates an example dm
object from the tables in nycflights13,
along with the references.
See nycflights13::flights
for a description of the data.
As described in nycflights13::planes
, the relationship
between the flights
table and the planes
tables is "weak", it does not satisfy
data integrity constraints.
dm_nycflights13( ..., cycle = FALSE, color = TRUE, subset = TRUE, compound = TRUE, table_description = FALSE )
dm_nycflights13( ..., cycle = FALSE, color = TRUE, subset = TRUE, compound = TRUE, table_description = FALSE )
... |
These dots are for future extensions and must be empty. |
cycle |
Boolean.
If |
color |
Boolean, if |
subset |
Boolean, if |
compound |
Boolean, if |
table_description |
Boolean, if |
A dm
object consisting of nycflights13 tables, complete with primary and foreign keys and optionally colored.
vignette("howto-dm-df")
dm_nycflights13() %>% dm_draw()
dm_nycflights13() %>% dm_draw()
dm_pack_tbl()
converts a parent table to a packed column in its child
table.
The parent table should not have parent tables itself (i.e. it needs to be a
terminal parent table).
dm_pack_tbl(dm, parent_table, into = NULL)
dm_pack_tbl(dm, parent_table, into = NULL)
dm |
A dm. |
parent_table |
A terminal table with one child table. |
into |
The table to pack |
dm_wrap_tbl()
, dm_unwrap_tbl()
, dm_nest_tbl()
.
dm_packed <- dm_nycflights13() %>% dm_pack_tbl(planes) dm_packed dm_packed$flights dm_packed$flights$planes
dm_packed <- dm_nycflights13() %>% dm_pack_tbl(planes) dm_packed dm_packed$flights dm_packed$flights$planes
dm_paste()
takes an existing dm
and emits the code necessary for its creation.
dm_paste(dm, select = NULL, ..., tab_width = 2, options = NULL, path = NULL)
dm_paste(dm, select = NULL, ..., tab_width = 2, options = NULL, path = NULL)
dm |
A |
select |
Deprecated, see |
... |
Must be empty. |
tab_width |
Indentation width for code from the second line onwards |
options |
Formatting options. A character vector containing some of:
Default |
path |
Output file, if |
The code emitted by the function reproduces the structure of the dm
object.
The options
argument controls the level of detail: keys, colors,
table definitions.
Data in the tables is never included, see dm_ptype()
for the underlying logic.
Code for producing the prototype of the given dm
.
dm() %>% dm_paste() dm_nycflights13() %>% dm_paste() dm_nycflights13() %>% dm_paste(options = "select")
dm() %>% dm_paste() dm_nycflights13() %>% dm_paste() dm_nycflights13() %>% dm_paste(options = "select")
Creates an example dm
object from the tables in
pixarfilms, along with the references.
dm_pixarfilms(..., color = TRUE, consistent = FALSE)
dm_pixarfilms(..., color = TRUE, consistent = FALSE)
... |
These dots are for future extensions and must be empty. |
color |
Boolean, if |
consistent |
Boolean, In the original |
A dm
object consisting of pixarfilms tables, complete with
primary and foreign keys and optionally colored.
dm_pixarfilms() dm_pixarfilms() %>% dm_draw()
dm_pixarfilms() dm_pixarfilms() %>% dm_draw()
The prototype contains all tables, all primary and foreign keys, but no data. All tables are truncated and converted to zero-row tibbles, also for remote data models. Columns retain their type. This is useful for performing creation and population of a database in separate steps.
dm_ptype(dm)
dm_ptype(dm)
dm |
A |
dm_financial() %>% dm_ptype() dm_financial() %>% dm_ptype() %>% dm_nrow()
dm_financial() %>% dm_ptype() dm_financial() %>% dm_ptype() %>% dm_nrow()
Rename the columns of your dm
using syntax that is similar to dplyr::rename()
.
dm_rename(dm, table, ...)
dm_rename(dm, table, ...)
dm |
A |
table |
A table in the |
... |
One or more unquoted expressions separated by commas.
You can treat
variable names as if they were positions, and use expressions like Use named arguments, e.g. The arguments in ... are automatically quoted and evaluated in a context where
column names represent column positions.
They also support unquoting and splicing.
See See select helpers for more details, and the examples about tidyselect helpers, such as |
If key columns are renamed, then the meta-information of the dm
is updated accordingly.
An updated dm
with the columns of table
renamed.
dm_nycflights13() %>% dm_rename(airports, code = faa, altitude = alt)
dm_nycflights13() %>% dm_rename(airports, code = faa, altitude = alt)
dm_rm_fk()
can remove either one reference between two tables, or multiple references at once (with a message).
An error is thrown if no matching foreign key is found.
dm_rm_fk( dm, table = NULL, columns = NULL, ref_table = NULL, ref_columns = NULL, ... )
dm_rm_fk( dm, table = NULL, columns = NULL, ref_table = NULL, ref_columns = NULL, ... )
dm |
A |
table |
A table in the |
columns |
Table columns, unquoted.
To refer to a compound key, use |
ref_table |
The table referenced by the |
ref_columns |
The columns of |
... |
These dots are for future extensions and must be empty. |
An updated dm
without the matching foreign key relation(s).
Other foreign key functions:
dm_add_fk()
,
dm_enum_fk_candidates()
,
dm_get_all_fks()
dm_nycflights13(cycle = TRUE) %>% dm_rm_fk(flights, dest, airports) %>% dm_draw()
dm_nycflights13(cycle = TRUE) %>% dm_rm_fk(flights, dest, airports) %>% dm_draw()
If a table name is provided, dm_rm_pk()
removes the primary key from this table and leaves the dm
object otherwise unaltered.
If no table is given, the dm
is stripped of all primary keys at once.
An error is thrown if no primary key matches the selection criteria.
If the selection criteria are ambiguous, a message with unambiguous replacement code is shown.
Foreign keys are never removed.
dm_rm_pk(dm, table = NULL, columns = NULL, ..., fail_fk = NULL)
dm_rm_pk(dm, table = NULL, columns = NULL, ..., fail_fk = NULL)
dm |
A |
table |
A table in the |
columns |
Table columns, unquoted.
To refer to a compound key, use |
... |
These dots are for future extensions and must be empty. |
fail_fk |
An updated dm
without the indicated primary key(s).
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_uk()
,
enum_pk_candidates()
dm_nycflights13() %>% dm_rm_pk(airports) %>% dm_draw()
dm_nycflights13() %>% dm_rm_pk(airports) %>% dm_draw()
dm_rm_uk()
removes one or more unique keys from a table and leaves the dm
object otherwise unaltered.
An error is thrown if no unique key matches the selection criteria.
If the selection criteria are ambiguous, a message with unambiguous replacement code is shown.
Foreign keys are never removed.
dm_rm_uk(dm, table = NULL, columns = NULL, ...)
dm_rm_uk(dm, table = NULL, columns = NULL, ...)
dm |
A |
table |
A table in the |
columns |
Table columns, unquoted.
To refer to a compound key, use |
... |
These dots are for future extensions and must be empty. |
An updated dm
without the indicated unique key(s).
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_pk()
,
enum_pk_candidates()
Select columns of your dm
using syntax that is similar to dplyr::select()
.
dm_select(dm, table, ...)
dm_select(dm, table, ...)
dm |
A |
table |
A table in the |
... |
One or more unquoted expressions separated by commas.
You can treat
variable names as if they were positions, and use expressions like Use named arguments, e.g. The arguments in ... are automatically quoted and evaluated in a context where
column names represent column positions.
They also support unquoting and splicing.
See See select helpers for more details, and the examples about tidyselect helpers, such as |
If key columns are renamed, then the meta-information of the dm
is updated accordingly.
If key columns are removed, then all related relations are dropped as well.
An updated dm
with the columns of table
reduced and/or renamed.
dm_nycflights13() %>% dm_select(airports, code = faa, altitude = alt)
dm_nycflights13() %>% dm_select(airports, code = faa, altitude = alt)
dm_select_tbl()
keeps the selected tables and their relationships,
optionally renaming them.
dm_rename_tbl()
renames tables.
dm_select_tbl(dm, ...) dm_rename_tbl(dm, ...)
dm_select_tbl(dm, ...) dm_rename_tbl(dm, ...)
dm |
A |
... |
One or more table names of the tables of the |
The input dm
with tables renamed or removed.
dm_nycflights13() %>% dm_select_tbl(airports, fl = flights) dm_nycflights13() %>% dm_rename_tbl(ap = airports, fl = flights)
dm_nycflights13() %>% dm_select_tbl(airports, fl = flights) dm_nycflights13() %>% dm_rename_tbl(ap = airports, fl = flights)
dm_set_colors()
allows to define the colors that will be used to display the tables of the data model with dm_draw()
.
The colors can either be specified with hex color codes or using the names of the built-in R colors.
An overview of the colors corresponding to the standard color names can be found at
the bottom of
https://rpubs.com/krlmlr/colors.
dm_get_colors()
returns the colors defined for a data model.
dm_get_available_colors()
returns an overview of the names of the available colors
These are the standard colors also returned by grDevices::colors()
plus a default
table color with the name "default".
dm_set_colors(dm, ...) dm_get_colors(dm) dm_get_available_colors()
dm_set_colors(dm, ...) dm_get_colors(dm) dm_get_available_colors()
dm |
A |
... |
Colors to set in the form |
For dm_set_colors()
: the updated data model.
For dm_get_colors()
, a named character vector of table names
with the colors in the names.
This allows calling dm_set_colors(!!!dm_get_colors(...))
.
Use tibble::enframe()
to convert this to a tibble.
For dm_get_available_colors()
, a vector with the available colors.
dm_nycflights13(color = FALSE) %>% dm_set_colors( darkblue = starts_with("air"), "#5986C4" = flights ) %>% dm_draw() # Splicing is supported: nyc_cols <- dm_nycflights13() %>% dm_get_colors() nyc_cols dm_nycflights13(color = FALSE) %>% dm_set_colors(!!!nyc_cols) %>% dm_draw()
dm_nycflights13(color = FALSE) %>% dm_set_colors( darkblue = starts_with("air"), "#5986C4" = flights ) %>% dm_draw() # Splicing is supported: nyc_cols <- dm_nycflights13() %>% dm_get_colors() nyc_cols dm_nycflights13(color = FALSE) %>% dm_set_colors(!!!nyc_cols) %>% dm_draw()
When creating a diagram from a dm
using dm_draw()
the table descriptions set with dm_set_table_description()
will be displayed.
dm_set_table_description(dm, ...) dm_get_table_description(dm, table = NULL, ...) dm_reset_table_description(dm, table = NULL, ...)
dm_set_table_description(dm, ...) dm_get_table_description(dm, table = NULL, ...) dm_reset_table_description(dm, table = NULL, ...)
dm |
A |
... |
For For |
table |
One or more table names, unquoted, for which to
In both cases the default applies to all tables in the |
Multi-line descriptions can be achieved using the newline symbol \n
.
Descriptions are set with dm_set_table_description()
.
The currently set descriptions can be checked using dm_get_table_description()
.
Descriptions can be removed using dm_reset_table_description()
.
For dm_set_table_description()
: A dm
object containing descriptions for specified tables.
For dm_get_table_description
: A named vector of tables, with the descriptions in the names.
For dm_reset_table_description()
: A dm
object without descriptions for specified tables.
desc_flights <- rlang::set_names( "flights", paste( "On-time data for all flights", "that departed NYC (i.e. JFK, LGA or EWR) in 2013.", sep = "\n" ) ) nyc_desc <- dm_nycflights13() %>% dm_set_table_description( !!desc_flights, "Weather at the airport of\norigin at time of departure" = weather ) nyc_desc %>% dm_draw() dm_get_table_description(nyc_desc) dm_reset_table_description(nyc_desc, flights) %>% dm_draw(font_size = c(header = 18L, table_description = 9L, column = 15L)) pull_tbl(nyc_desc, flights) %>% labelled::label_attribute()
desc_flights <- rlang::set_names( "flights", paste( "On-time data for all flights", "that departed NYC (i.e. JFK, LGA or EWR) in 2013.", sep = "\n" ) ) nyc_desc <- dm_nycflights13() %>% dm_set_table_description( !!desc_flights, "Weather at the airport of\norigin at time of departure" = weather ) nyc_desc %>% dm_draw() dm_get_table_description(nyc_desc) dm_reset_table_description(nyc_desc, flights) %>% dm_draw(font_size = c(header = 18L, table_description = 9L, column = 15L)) pull_tbl(nyc_desc, flights) %>% labelled::label_attribute()
dm
a and database connectionGenerate SQL scripts to create tables, load data and set constraints, keys and indices.
This function powers copy_dm_to()
and is useful if you need more control
over the process of copying a dm
to a database.
dm_sql(dm, dest, table_names = NULL, temporary = TRUE) dm_ddl_pre(dm, dest, table_names = NULL, temporary = TRUE) dm_dml_load(dm, dest, table_names = NULL, temporary = TRUE) dm_ddl_post(dm, dest, table_names = NULL, temporary = TRUE)
dm_sql(dm, dest, table_names = NULL, temporary = TRUE) dm_ddl_pre(dm, dest, table_names = NULL, temporary = TRUE) dm_dml_load(dm, dest, table_names = NULL, temporary = TRUE) dm_ddl_post(dm, dest, table_names = NULL, temporary = TRUE)
dm |
A |
dest |
Connection to database. |
table_names |
A named character vector or named vector of DBI::Id,
DBI::SQL or dbplyr objects created with |
temporary |
Should the tables be marked as temporary? Defaults to |
dm_ddl_pre()
generates CREATE TABLE
statements (including PRIMARY KEY
definition).
dm_dml_load()
generates INSERT INTO
statements.
dm_ddl_post()
generates scripts for FOREIGN KEY
, UNIQUE KEY
and INDEX
.
dm_sql()
calls all three above and returns a complete set of scripts.
Nested list of SQL statements.
con <- DBI::dbConnect(RSQLite::SQLite()) dm <- dm_nycflights13() s <- dm_sql(dm, con) s DBI::dbDisconnect(con)
con <- DBI::dbConnect(RSQLite::SQLite()) dm <- dm_nycflights13() s <- dm_sql(dm, con) s DBI::dbDisconnect(con)
dm_unnest_tbl()
target a specific column to unnest
from the given table in a given dm.
A ptype or a set of keys should be given, not both.
dm_unnest_tbl(dm, parent_table, col, ptype)
dm_unnest_tbl(dm, parent_table, col, ptype)
dm |
A dm. |
parent_table |
A table in the dm with nested columns. |
col |
The column to unnest (unquoted). |
ptype |
A dm, only used to query names of primary and foreign keys. |
dm_nest_tbl()
is an inverse operation to dm_unnest_tbl()
if differences in row and column order are ignored.
The opposite is true if referential constraints between both tables
are satisfied.
A dm.
dm_unwrap_tbl()
, dm_unpack_tbl()
,
dm_nest_tbl()
, dm_pack_tbl()
, dm_wrap_tbl()
,
dm_examine_constraints()
, dm_examine_cardinalities()
,
dm_ptype()
.
airlines_wrapped <- dm_nycflights13() %>% dm_wrap_tbl(airlines) # The ptype is required for reconstruction. # It can be an empty dm, only primary and foreign keys are considered. ptype <- dm_ptype(dm_nycflights13()) airlines_wrapped %>% dm_unnest_tbl(airlines, flights, ptype)
airlines_wrapped <- dm_nycflights13() %>% dm_wrap_tbl(airlines) # The ptype is required for reconstruction. # It can be an empty dm, only primary and foreign keys are considered. ptype <- dm_ptype(dm_nycflights13()) airlines_wrapped %>% dm_unnest_tbl(airlines, flights, ptype)
dm_unpack_tbl(dm, child_table, col, ptype)
dm_unpack_tbl(dm, child_table, col, ptype)
dm |
A dm. |
child_table |
A table in the dm with packed columns. |
col |
The column to unpack (unquoted). |
ptype |
A dm, only used to query names of primary and foreign keys. |
dm_unpack_tbl()
targets a specific column to unpack
from the given table in a given dm.
A ptype or a set of keys should be given,
not both.
dm_pack_tbl()
is an inverse operation to dm_unpack_tbl()
if differences in row and column order are ignored.
The opposite is true if referential constraints between both tables
are satisfied
and if all rows in the parent table have at least one child row,
i.e. if the relationship is of cardinality 1:n or 1:1.
dm_unwrap_tbl()
, dm_unnest_tbl()
,
dm_nest_tbl()
, dm_pack_tbl()
, dm_wrap_tbl()
,
dm_examine_constraints()
, dm_examine_cardinalities()
,
dm_ptype()
.
flights_wrapped <- dm_nycflights13() %>% dm_wrap_tbl(flights) # The ptype is required for reconstruction. # It can be an empty dm, only primary and foreign keys are considered. ptype <- dm_ptype(dm_nycflights13()) flights_wrapped %>% dm_unpack_tbl(flights, airlines, ptype)
flights_wrapped <- dm_nycflights13() %>% dm_wrap_tbl(flights) # The ptype is required for reconstruction. # It can be an empty dm, only primary and foreign keys are considered. ptype <- dm_ptype(dm_nycflights13()) flights_wrapped %>% dm_unpack_tbl(flights, airlines, ptype)
dm_unwrap_tbl()
unwraps all tables in a dm object so that the resulting dm
matches a given ptype dm.
It runs a sequence of dm_unnest_tbl()
and dm_unpack_tbl()
operations
on the dm.
dm_unwrap_tbl(dm, ptype, progress = NA)
dm_unwrap_tbl(dm, ptype, progress = NA)
dm |
A dm. |
ptype |
A dm, only used to query names of primary and foreign keys. |
progress |
Whether to display a progress bar, if |
A dm.
dm_wrap_tbl()
, dm_unnest_tbl()
,
dm_examine_constraints()
,
dm_examine_cardinalities()
,
dm_ptype()
.
roundtrip <- dm_nycflights13() %>% dm_wrap_tbl(root = flights) %>% dm_unwrap_tbl(ptype = dm_ptype(dm_nycflights13())) roundtrip # The roundtrip has the same structure but fewer rows: dm_nrow(dm_nycflights13()) dm_nrow(roundtrip)
roundtrip <- dm_nycflights13() %>% dm_wrap_tbl(root = flights) %>% dm_unwrap_tbl(ptype = dm_ptype(dm_nycflights13())) roundtrip # The roundtrip has the same structure but fewer rows: dm_nrow(dm_nycflights13()) dm_nrow(roundtrip)
dm_validate()
checks the internal consistency of a dm
object.
dm_validate(x)
dm_validate(x)
x |
An object. |
In theory, with the exception of new_dm()
, all dm
objects
created or modified by functions in this package should be valid,
and this function should not be needed.
Please file an issue if any dm operation creates an invalid object.
Returns the dm
, invisibly, after finishing all checks.
dm_validate(dm()) bad_dm <- structure(list(bad = "dm"), class = "dm") try(dm_validate(bad_dm))
dm_validate(dm()) bad_dm <- structure(list(bad = "dm"), class = "dm") try(dm_validate(bad_dm))
dm_wrap_tbl()
creates a single tibble dm containing the root
table
enhanced with all the data related to it
through the relationships stored in the dm.
It runs a sequence of dm_nest_tbl()
and dm_pack_tbl()
operations
on the dm.
dm_wrap_tbl(dm, root, strict = TRUE, progress = NA)
dm_wrap_tbl(dm, root, strict = TRUE, progress = NA)
dm |
A cycle free dm object. |
root |
Table to wrap the dm into (unquoted). |
strict |
Whether to fail for cyclic dms that cannot be wrapped into a
single table, if |
progress |
Whether to display a progress bar, if |
dm_wrap_tbl()
is an inverse to dm_unwrap_tbl()
,
i.e., wrapping after unwrapping returns the same information
(disregarding row and column order).
The opposite is not generally true:
since dm_wrap_tbl()
keeps only rows related directly or indirectly to
rows in the root
table.
Even if all referential constraints are satisfied,
unwrapping after wrapping loses rows in parent tables
that don't have a corresponding row in the child table.
This function differs from dm_flatten_to_tbl()
and dm_squash_to_tbl()
,
which always return a single table, and not a dm
object.
A dm
object.
dm_unwrap_tbl()
, dm_nest_tbl()
,
dm_examine_constraints()
,
dm_examine_cardinalities()
.
dm_nycflights13() %>% dm_wrap_tbl(root = airlines)
dm_nycflights13() %>% dm_wrap_tbl(root = airlines)
Zooming to a table of a dm
allows for the use of many dplyr
-verbs directly on this table, while retaining the
context of the dm
object.
dm_zoom_to()
zooms to the given table.
dm_update_zoomed()
overwrites the originally zoomed table with the manipulated table.
The filter conditions for the zoomed table are added to the original filter conditions.
dm_insert_zoomed()
adds a new table to the dm
.
dm_discard_zoomed()
discards the zoomed table and returns the dm
as it was before zooming.
Please refer to vignette("tech-db-zoom", package = "dm")
for a more detailed introduction.
dm_zoom_to(dm, table) dm_insert_zoomed(dm, new_tbl_name = NULL, repair = "unique", quiet = FALSE) dm_update_zoomed(dm) dm_discard_zoomed(dm)
dm_zoom_to(dm, table) dm_insert_zoomed(dm, new_tbl_name = NULL, repair = "unique", quiet = FALSE) dm_update_zoomed(dm) dm_discard_zoomed(dm)
dm |
A |
table |
A table in the |
new_tbl_name |
Name of the new table. |
repair |
Either a string or a function. If a string, it must be one of
The The options |
quiet |
By default, the user is informed of any renaming
caused by repairing the names. This only concerns unique and
universal repairing. Set Users can silence the name repair messages by setting the
|
Whenever possible, the key relations of the original table are transferred to the resulting table
when using dm_insert_zoomed()
or dm_update_zoomed()
.
Functions from dplyr
that are supported for a dm_zoomed
: group_by()
, summarise()
, mutate()
,
transmute()
, filter()
, select()
, rename()
and ungroup()
.
You can use these functions just like you would
with a normal table.
Calling filter()
on a zoomed dm
is different from calling dm_filter()
:
only with the latter, the filter expression is added to the list of table filters stored in the dm.
Furthermore, different join()
-variants from dplyr are also supported,
e.g. left_join()
and semi_join()
.
(Support for dplyr::nest_join()
is planned.)
The join-methods for dm_zoomed
infer the columns to join by from the primary and foreign keys,
and have an extra argument select
that allows choosing the columns of the RHS table.
And – last but not least – also the tidyr-functions unite()
and separate()
are supported for dm_zoomed
.
For dm_zoom_to()
: A dm_zoomed
object.
For dm_insert_zoomed()
, dm_update_zoomed()
and dm_discard_zoomed()
: A dm
object.
flights_zoomed <- dm_zoom_to(dm_nycflights13(), flights) flights_zoomed flights_zoomed_transformed <- flights_zoomed %>% mutate(am_pm_dep = ifelse(dep_time < 1200, "am", "pm")) %>% # `by`-argument of `left_join()` can be explicitly given # otherwise the key-relation is used left_join(airports) %>% select(year:dep_time, am_pm_dep, everything()) flights_zoomed_transformed # replace table `flights` with the zoomed table flights_zoomed_transformed %>% dm_update_zoomed() # insert the zoomed table as a new table flights_zoomed_transformed %>% dm_insert_zoomed("extended_flights") %>% dm_draw() # discard the zoomed table flights_zoomed_transformed %>% dm_discard_zoomed()
flights_zoomed <- dm_zoom_to(dm_nycflights13(), flights) flights_zoomed flights_zoomed_transformed <- flights_zoomed %>% mutate(am_pm_dep = ifelse(dep_time < 1200, "am", "pm")) %>% # `by`-argument of `left_join()` can be explicitly given # otherwise the key-relation is used left_join(airports) %>% select(year:dep_time, am_pm_dep, everything()) flights_zoomed_transformed # replace table `flights` with the zoomed table flights_zoomed_transformed %>% dm_update_zoomed() # insert the zoomed table as a new table flights_zoomed_transformed %>% dm_insert_zoomed("extended_flights") %>% dm_draw() # discard the zoomed table flights_zoomed_transformed %>% dm_discard_zoomed()
Use these methods without the '.dm_zoomed' suffix (see examples).
## S3 method for class 'dm_zoomed' left_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' left_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' inner_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' inner_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' full_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' full_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' right_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' right_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' semi_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' semi_join(x, y, by = NULL, copy = NULL, ...) ## S3 method for class 'dm_zoomed' anti_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' anti_join(x, y, by = NULL, copy = NULL, ...) ## S3 method for class 'dm_zoomed' nest_join(x, y, by = NULL, copy = FALSE, keep = FALSE, name = NULL, ...)
## S3 method for class 'dm_zoomed' left_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' left_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' inner_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' inner_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' full_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' full_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' right_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' right_join(x, y, by = NULL, copy = NULL, suffix = NULL, ..., keep = FALSE) ## S3 method for class 'dm_zoomed' semi_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' semi_join(x, y, by = NULL, copy = NULL, ...) ## S3 method for class 'dm_zoomed' anti_join(x, y, by = NULL, copy = NULL, suffix = NULL, select = NULL, ...) ## S3 method for class 'dm_keyed_tbl' anti_join(x, y, by = NULL, copy = NULL, ...) ## S3 method for class 'dm_zoomed' nest_join(x, y, by = NULL, copy = FALSE, keep = FALSE, name = NULL, ...)
x , y
|
tbls to join. |
by |
If left |
copy |
Disabled, since all tables in a |
suffix |
Disabled, since columns are disambiguated automatically if necessary, changing the column names to |
select |
Select a subset of the RHS-table's columns, the syntax being |
... |
see |
keep |
Should the new list-column contain join keys? The default will preserve the join keys for inequality joins. |
name |
The name of the list-column created by the join. If |
flights_dm <- dm_nycflights13() dm_zoom_to(flights_dm, flights) %>% left_join(airports, select = c(faa, name)) # this should illustrate that tables don't necessarily need to be connected dm_zoom_to(flights_dm, airports) %>% semi_join(airlines, by = "name")
flights_dm <- dm_nycflights13() dm_zoom_to(flights_dm, flights) %>% left_join(airports, select = c(faa, name)) # this should illustrate that tables don't necessarily need to be connected dm_zoom_to(flights_dm, airports) %>% semi_join(airlines, by = "name")
Use these methods without the '.dm_zoomed' suffix (see examples).
## S3 method for class 'dm_zoomed' filter(.data, ...) ## S3 method for class 'dm_zoomed' mutate(.data, ...) ## S3 method for class 'dm_zoomed' transmute(.data, ...) ## S3 method for class 'dm_zoomed' select(.data, ...) ## S3 method for class 'dm_zoomed' relocate(.data, ..., .before = NULL, .after = NULL) ## S3 method for class 'dm_zoomed' rename(.data, ...) ## S3 method for class 'dm_zoomed' distinct(.data, ..., .keep_all = FALSE) ## S3 method for class 'dm_zoomed' arrange(.data, ...) ## S3 method for class 'dm_zoomed' slice(.data, ..., .keep_pk = NULL) ## S3 method for class 'dm_zoomed' group_by(.data, ...) ## S3 method for class 'dm_keyed_tbl' group_by(.data, ...) ## S3 method for class 'dm_zoomed' ungroup(x, ...) ## S3 method for class 'dm_zoomed' summarise(.data, ...) ## S3 method for class 'dm_keyed_tbl' summarise(.data, ...) ## S3 method for class 'dm_zoomed' count( x, ..., wt = NULL, sort = FALSE, name = NULL, .drop = group_by_drop_default(x) ) ## S3 method for class 'dm_zoomed' tally(x, ...) ## S3 method for class 'dm_zoomed' pull(.data, var = -1, ...) ## S3 method for class 'dm_zoomed' compute(x, ...)
## S3 method for class 'dm_zoomed' filter(.data, ...) ## S3 method for class 'dm_zoomed' mutate(.data, ...) ## S3 method for class 'dm_zoomed' transmute(.data, ...) ## S3 method for class 'dm_zoomed' select(.data, ...) ## S3 method for class 'dm_zoomed' relocate(.data, ..., .before = NULL, .after = NULL) ## S3 method for class 'dm_zoomed' rename(.data, ...) ## S3 method for class 'dm_zoomed' distinct(.data, ..., .keep_all = FALSE) ## S3 method for class 'dm_zoomed' arrange(.data, ...) ## S3 method for class 'dm_zoomed' slice(.data, ..., .keep_pk = NULL) ## S3 method for class 'dm_zoomed' group_by(.data, ...) ## S3 method for class 'dm_keyed_tbl' group_by(.data, ...) ## S3 method for class 'dm_zoomed' ungroup(x, ...) ## S3 method for class 'dm_zoomed' summarise(.data, ...) ## S3 method for class 'dm_keyed_tbl' summarise(.data, ...) ## S3 method for class 'dm_zoomed' count( x, ..., wt = NULL, sort = FALSE, name = NULL, .drop = group_by_drop_default(x) ) ## S3 method for class 'dm_zoomed' tally(x, ...) ## S3 method for class 'dm_zoomed' pull(.data, var = -1, ...) ## S3 method for class 'dm_zoomed' compute(x, ...)
.data |
object of class |
... |
see corresponding function in package dplyr or tidyr |
.before , .after
|
< |
.keep_all |
For |
.keep_pk |
For |
x |
For |
wt |
<
|
sort |
If |
name |
The name of the new column in the output. If omitted, it will default to |
.drop |
Handling of factor levels that don't appear in the data, passed
on to For For |
var |
A variable specified as:
The default returns the last column (on the assumption that's the column you've created most recently). This argument is taken by expression and supports quasiquotation (you can unquote column names and column locations). |
zoomed <- dm_nycflights13() %>% dm_zoom_to(flights) %>% group_by(month) %>% arrange(desc(day)) %>% summarize(avg_air_time = mean(air_time, na.rm = TRUE)) zoomed dm_insert_zoomed(zoomed, new_tbl_name = "avg_air_time_per_month")
zoomed <- dm_nycflights13() %>% dm_zoom_to(flights) %>% group_by(month) %>% arrange(desc(day)) %>% summarize(avg_air_time = mean(air_time, na.rm = TRUE)) zoomed dm_insert_zoomed(zoomed, new_tbl_name = "avg_air_time_per_month")
enum_pk_candidates()
checks for each column of a
table if the column contains only unique values, and is thus
a suitable candidate for a primary key of the table.
dm_enum_pk_candidates()
performs these checks
for a table in a dm object.
enum_pk_candidates(table, ...) dm_enum_pk_candidates(dm, table, ...)
enum_pk_candidates(table, ...) dm_enum_pk_candidates(dm, table, ...)
table |
A table in the |
... |
These dots are for future extensions and must be empty. |
dm |
A |
A tibble with the following columns:
columns
columns of table
,
candidate
boolean: are these columns a candidate for a primary key,
why
if not a candidate for a primary key column, explanation for this.
These functions are marked "experimental" because we are not yet sure about
the interface, in particular if we need both dm_enum...()
and enum...()
variants.
Changing the interface later seems harmless because these functions are
most likely used interactively.
Other primary key functions:
dm_add_pk()
,
dm_add_uk()
,
dm_get_all_pks()
,
dm_get_all_uks()
,
dm_has_pk()
,
dm_rm_pk()
,
dm_rm_uk()
nycflights13::flights %>% enum_pk_candidates() dm_nycflights13() %>% dm_enum_pk_candidates(airports)
nycflights13::flights %>% enum_pk_candidates() dm_nycflights13() %>% dm_enum_pk_candidates(airports)
All check_cardinality_...()
functions test the following conditions:
Are all rows in x
unique?
Are the rows in y
a subset of the rows in x
?
Does the relation between x
and y
meet the cardinality requirements?
One row from x
must correspond to the requested number of rows in y
,
e.g. _0_1
means that there must be zero or one rows in y
for each
row in x
.
examine_cardinality()
also checks the first two points and subsequently determines the type of cardinality.
For convenience, the x_select
and y_select
arguments allow restricting the check
to a set of key columns without affecting the return value.
check_cardinality_0_n( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_1_n( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_1_1( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_0_1( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) examine_cardinality( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL )
check_cardinality_0_n( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_1_n( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_1_1( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) check_cardinality_0_1( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL ) examine_cardinality( x, y, ..., x_select = NULL, y_select = NULL, by_position = NULL )
x |
Parent table, data frame or lazy table. |
y |
Child table, data frame or lazy table. |
... |
These dots are for future extensions and must be empty. |
x_select , y_select
|
Key columns to restrict the check, processed with
|
by_position |
Set to |
All cardinality functions accept a parent and a child table (x
and y
).
All rows in x
must be unique, and all rows in y
must be a subset of the
rows in x
.
The x_select
and y_select
arguments allow restricting the check
to a set of key columns without affecting the return value.
If given, both arguments must refer to the same number of key columns.
The cardinality specifications "0_n", "1_n", "0_1", "1_1" refer to the expected relation that the child table has with the parent table.
"0", "1" and "n" refer to the occurrences of value combinations
in y
that correspond to each combination in the
columns of the parent table.
"n" means "more than one" in this context, with no upper limit.
"0_n": no restrictions, each row in x
has at least 0 and at most
n corresponding occurrences in y
.
"1_n": each row in x
has at least 1 and at most
n corresponding occurrences in y
.
This means that there is a "surjective" mapping from the child table
to the parent table, i.e. each parent table row exists at least once in the
child table.
"0_1": each row in x
has at least 0 and at most
1 corresponding occurrence in y
.
This means that there is a "injective" mapping from the child table
to the parent table, i.e. no combination of values in the
parent table columns is addressed multiple times.
But not all parent table rows have to be referred to.
"1_1": each row in x
occurs exactly once in y
.
This means that there is a "bijective" ("injective" AND "surjective") mapping
between the child table and the parent table, i.e. the
sets of rows are identical.
Finally, examine_cardinality()
tests for and returns the nature of the relationship
(injective, surjective, bijective, or none of these)
between the two given sets of columns.
If either x
is not unique or there are rows in y
that are missing from x
,
the requirements for a cardinality test is not fulfilled.
No error will be thrown, but
the result will contain the information which prerequisite was violated.
check_cardinality_...()
return x
, invisibly,
if the check is passed, to support pipes.
Otherwise an error is thrown and the reason for it is explained.
examine_cardinality()
returns a character variable specifying the type of relationship between the two columns.
Other cardinality functions:
dm_examine_cardinalities()
d1 <- tibble::tibble(a = 1:5) d2 <- tibble::tibble(a = c(1:4, 4L)) d3 <- tibble::tibble(c = c(1:5, 5L), d = 0) # This does not pass, `a` is not unique key of d2: try(check_cardinality_0_n(d2, d1)) # Columns are matched by name by default: try(check_cardinality_0_n(d1, d3)) # This passes, multiple values in d3$c are allowed: check_cardinality_0_n(d1, d2) # This does not pass, injectivity is violated: try(check_cardinality_1_1(d1, d3, y_select = c(a = c))) try(check_cardinality_0_1(d1, d3, x_select = c(c = a))) # What kind of cardinality is it? examine_cardinality(d1, d3, x_select = c(c = a)) examine_cardinality(d1, d2)
d1 <- tibble::tibble(a = 1:5) d2 <- tibble::tibble(a = c(1:4, 4L)) d3 <- tibble::tibble(c = c(1:5, 5L), d = 0) # This does not pass, `a` is not unique key of d2: try(check_cardinality_0_n(d2, d1)) # Columns are matched by name by default: try(check_cardinality_0_n(d1, d3)) # This passes, multiple values in d3$c are allowed: check_cardinality_0_n(d1, d2) # This does not pass, injectivity is violated: try(check_cardinality_1_1(d1, d3, y_select = c(a = c))) try(check_cardinality_0_1(d1, d3, x_select = c(c = a))) # What kind of cardinality is it? examine_cardinality(d1, d3, x_select = c(c = a)) examine_cardinality(d1, d2)
dm
objectglimpse()
provides an overview (dimensions, column data types, primary
keys, etc.) of all tables included in the dm
object. It will additionally
print details about outgoing foreign keys for the child table.
glimpse()
is provided by the pillar package, and re-exported by dm.
See pillar::glimpse()
for more details.
## S3 method for class 'dm' glimpse(x, width = NULL, ...) ## S3 method for class 'dm_zoomed' glimpse(x, width = NULL, ...)
## S3 method for class 'dm' glimpse(x, width = NULL, ...) ## S3 method for class 'dm_zoomed' glimpse(x, width = NULL, ...)
x |
A |
width |
Controls the maximum number of columns on a line used in
printing. If |
... |
Passed to |
dm_nycflights13() %>% glimpse() dm_nycflights13() %>% dm_zoom_to(flights) %>% glimpse()
dm_nycflights13() %>% glimpse() dm_nycflights13() %>% dm_zoom_to(flights) %>% glimpse()
dm_zoomed
objectsExtract the first or last rows from a table.
Use these methods without the '.dm_zoomed' suffix (see examples).
The methods for regular dm
objects extract the first or last tables.
## S3 method for class 'dm_zoomed' head(x, n = 6L, ...) ## S3 method for class 'dm_zoomed' tail(x, n = 6L, ...)
## S3 method for class 'dm_zoomed' head(x, n = 6L, ...) ## S3 method for class 'dm_zoomed' tail(x, n = 6L, ...)
x |
object of class |
n |
an integer vector of length up to |
... |
arguments to be passed to or from other methods. |
see manual for the corresponding functions in utils.
A dm_zoomed
object.
zoomed <- dm_nycflights13() %>% dm_zoom_to(flights) %>% head(4) zoomed dm_insert_zoomed(zoomed, new_tbl_name = "head_flights")
zoomed <- dm_nycflights13() %>% dm_zoom_to(flights) %>% head(4) zoomed dm_insert_zoomed(zoomed, new_tbl_name = "head_flights")
A wrapper around tidyr::nest()
which stores the nested data into JSON columns.
json_nest(.data, ..., .names_sep = NULL)
json_nest(.data, ..., .names_sep = NULL)
.data |
A data frame, a data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
... |
< |
.names_sep |
If |
tidyr::nest()
, json_nest_join()
df <- tibble::tibble(x = c(1, 1, 1, 2, 2, 3), y = 1:6, z = 6:1) nested <- json_nest(df, data = c(y, z)) nested
df <- tibble::tibble(x = c(1, 1, 1, 2, 2, 3), y = 1:6, z = 6:1) nested <- json_nest(df, data = c(y, z)) nested
A wrapper around dplyr::nest_join()
which stores the joined data into a JSON column.
json_nest_join()
returns all rows and columns in x
with a new JSON columns that contains all nested matches from y
.
json_nest_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
json_nest_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
x , y
|
A pair of data frames or data frame extensions (e.g. a tibble). |
by |
A join specification created with If To join on different variables between To join by multiple variables, use a
For simple equality joins, you can alternatively specify a character vector
of variable names to join by. For example, To perform a cross-join, generating all combinations of |
... |
Other parameters passed onto methods. |
copy |
If |
keep |
Should the new list-column contain join keys? The default will preserve the join keys for inequality joins. |
name |
The name of the list-column created by the join. If |
dplyr::nest_join()
, json_pack_join()
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) df3 <- json_nest_join(df1, df2) df3 df3$df2
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) df3 <- json_nest_join(df1, df2) df3 df3$df2
A wrapper around tidyr::pack()
which stores the packed data into JSON columns.
json_pack(.data, ..., .names_sep = NULL)
json_pack(.data, ..., .names_sep = NULL)
.data |
A data frame, a data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
... |
< |
.names_sep |
If |
tidyr::pack()
, json_pack_join()
df <- tibble::tibble(x1 = 1:3, x2 = 4:6, x3 = 7:9, y = 1:3) packed <- json_pack(df, x = c(x1, x2, x3), y = y) packed
df <- tibble::tibble(x1 = 1:3, x2 = 4:6, x3 = 7:9, y = 1:3) packed <- json_pack(df, x = c(x1, x2, x3), y = y) packed
A wrapper around pack_join()
which stores the joined data into a JSON column.
json_pack_join()
returns all rows and columns in x
with a new JSON columns that contains all packed matches from y
.
json_pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
json_pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
x , y
|
A pair of data frames or data frame extensions (e.g. a tibble). |
by |
A join specification created with If To join on different variables between To join by multiple variables, use a
For simple equality joins, you can alternatively specify a character vector
of variable names to join by. For example, To perform a cross-join, generating all combinations of |
... |
Other parameters passed onto methods. |
copy |
If |
keep |
Should the new list-column contain join keys? The default will preserve the join keys for inequality joins. |
name |
The name of the list-column created by the join. If |
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) df3 <- json_pack_join(df1, df2) df3 df3$df2
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) df3 <- json_pack_join(df1, df2) df3 df3$df2
A wrapper around tidyr::unnest()
that extracts its data from a JSON column.
The inverse of json_nest()
.
json_unnest(data, cols, ..., names_sep = NULL, names_repair = "check_unique")
json_unnest(data, cols, ..., names_sep = NULL, names_repair = "check_unique")
data |
A data frame, a data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
cols |
< When selecting multiple columns, values from the same row will be recycled to their common size. |
... |
Arguments passed to methods. |
names_sep |
If |
names_repair |
Used to check that output data frame has valid names. Must be one of the following options:
See |
An object of the same type as data
tibble(a = 1, b = '[{ "c": 2 }, { "c": 3 }]') %>% json_unnest(b)
tibble(a = 1, b = '[{ "c": 2 }, { "c": 3 }]') %>% json_unnest(b)
A wrapper around tidyr::unpack()
that extracts its data from a JSON column.
The inverse of json_pack()
.
json_unpack(data, cols, ..., names_sep = NULL, names_repair = "check_unique")
json_unpack(data, cols, ..., names_sep = NULL, names_repair = "check_unique")
data |
A data frame, a data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
cols |
< |
... |
Arguments passed to methods. |
names_sep |
If If a string, the inner and outer names will be used together. In
|
names_repair |
Used to check that output data frame has valid names. Must be one of the following options:
See |
An object of the same type as data
tibble(a = 1, b = '{ "c": 2, "d": 3 }') %>% json_unpack(b)
tibble(a = 1, b = '{ "c": 2, "d": 3 }') %>% json_unpack(b)
compute()
materializes all tables in a dm
to new temporary
tables on the database.
collect()
downloads the tables in a dm
object as local tibbles.
## S3 method for class 'dm' compute(x, ..., temporary = TRUE) ## S3 method for class 'dm' collect(x, ..., progress = NA)
## S3 method for class 'dm' compute(x, ..., temporary = TRUE) ## S3 method for class 'dm' collect(x, ..., progress = NA)
x |
A |
... |
Passed on to |
temporary |
Must remain |
progress |
Whether to display a progress bar, if |
Called on a dm
object, these methods create a copy of all tables in the dm
.
Depending on the size of your data this may take a long time.
To create permament tables, first create the database schema using copy_dm_to()
or dm_sql()
, and then use dm_rows_append()
.
A dm
object of the same structure as the input.
financial <- dm_financial_sqlite() financial %>% pull_tbl(districts) %>% dbplyr::remote_name() # compute() copies the data to new tables: financial %>% compute() %>% pull_tbl(districts) %>% dbplyr::remote_name() # collect() returns a local dm: financial %>% collect() %>% pull_tbl(districts) %>% class()
financial <- dm_financial_sqlite() financial %>% pull_tbl(districts) %>% dbplyr::remote_name() # compute() copies the data to new tables: financial %>% compute() %>% pull_tbl(districts) %>% dbplyr::remote_name() # collect() returns a local dm: financial %>% collect() %>% pull_tbl(districts) %>% class()
pack_join()
returns all rows and columns in x
with a new packed column
that contains all matches from y
.
pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL) ## S3 method for class 'dm_zoomed' pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL) ## S3 method for class 'dm_zoomed' pack_join(x, y, by = NULL, ..., copy = FALSE, keep = FALSE, name = NULL)
x , y
|
A pair of data frames or data frame extensions (e.g. a tibble). |
by |
A join specification created with If To join on different variables between To join by multiple variables, use a
For simple equality joins, you can alternatively specify a character vector
of variable names to join by. For example, To perform a cross-join, generating all combinations of |
... |
Other parameters passed onto methods. |
copy |
If |
keep |
Should the new list-column contain join keys? The default will preserve the join keys for inequality joins. |
name |
The name of the list-column created by the join. If |
dplyr::nest_join()
, tidyr::pack()
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) pack_join(df1, df2)
df1 <- tibble::tibble(x = 1:3) df2 <- tibble::tibble(x = c(1, 1, 2), y = c("first", "second", "third")) pack_join(df1, df2)
This generic has methods for both dm
classes:
With pull_tbl.dm()
you can chose which table of the dm
you want to retrieve.
With pull_tbl.dm_zoomed()
you will retrieve the zoomed table in the current state.
pull_tbl(dm, table, ..., keyed = FALSE)
pull_tbl(dm, table, ..., keyed = FALSE)
dm |
A |
table |
One unquoted table name for |
... |
These dots are for future extensions and must be empty. |
keyed |
Set to |
The requested table.
dm_deconstruct()
to generate code of the form
pull_tbl(..., keyed = TRUE)
from an existing dm
object.
# For an unzoomed dm you need to specify the table to pull: dm_nycflights13() %>% pull_tbl(airports) # If zoomed, pulling detaches the zoomed table from the dm: dm_nycflights13() %>% dm_zoom_to(airports) %>% pull_tbl()
# For an unzoomed dm you need to specify the table to pull: dm_nycflights13() %>% pull_tbl(airports) # If zoomed, pulling detaches the zoomed table from the dm: dm_nycflights13() %>% dm_zoom_to(airports) %>% pull_tbl()
Perform table fusion by combining two tables by a common (key) column, and then removing this column.
reunite_parent_child()
: After joining the two tables by the column id_column
, this column will be removed.
The transformation is roughly the
inverse of what decompose_table()
does.
reunite_parent_child_from_list()
: After joining the two tables
by the column id_column
, id_column
is removed.
This function is almost exactly the inverse of decompose_table()
(the order
of the columns is not retained, and the original row names are lost).
reunite_parent_child(child_table, parent_table, id_column) reunite_parent_child_from_list(list_of_parent_child_tables, id_column)
reunite_parent_child(child_table, parent_table, id_column) reunite_parent_child_from_list(list_of_parent_child_tables, id_column)
child_table |
Table (possibly created by |
parent_table |
Table (possibly created by |
id_column |
Identical name of referencing / referenced column in |
list_of_parent_child_tables |
Cf arguments |
A wide table produced by joining the two given tables.
These functions are marked "experimental" because they seem more useful when applied to a table in a dm object. Changing the interface later seems harmless because these functions are most likely used interactively.
Other table surgery functions:
decompose_table()
decomposed_table <- decompose_table(mtcars, new_id, am, gear, carb) ct <- decomposed_table$child_table pt <- decomposed_table$parent_table reunite_parent_child(ct, pt, new_id) reunite_parent_child_from_list(decomposed_table, new_id)
decomposed_table <- decompose_table(mtcars, new_id, am, gear, carb) ct <- decomposed_table$child_table pt <- decomposed_table$parent_table reunite_parent_child(ct, pt, new_id) reunite_parent_child_from_list(decomposed_table, new_id)
These functions provide a framework for updating data in existing tables.
Unlike compute()
, copy_to()
or copy_dm_to()
, no new tables are created
on the database.
All operations expect that both existing and new data are presented
in two compatible dm objects on the same data source.
The functions make sure that the tables in the target dm are processed in topological order so that parent (dimension) tables receive insertions before child (fact) tables.
These operations, in contrast to all other operations,
may lead to irreversible changes to the underlying database.
Therefore, in-place operation must be requested explicitly with in_place = TRUE
.
By default, an informative message is given.
dm_rows_insert()
adds new records via rows_insert()
with conflict = "ignore"
.
Duplicate records will be silently discarded.
This operation requires primary keys on all tables, use dm_rows_append()
to insert unconditionally.
dm_rows_append()
adds new records via rows_append()
.
The primary keys must differ from existing records.
This must be ensured by the caller and might be checked by the underlying database.
Use in_place = FALSE
and apply dm_examine_constraints()
to check beforehand.
dm_rows_update()
updates existing records via rows_update()
.
Primary keys must match for all records to be updated.
dm_rows_patch()
updates missing values in existing records
via rows_patch()
.
Primary keys must match for all records to be patched.
dm_rows_upsert()
updates existing records and adds new records,
based on the primary key, via rows_upsert()
.
dm_rows_delete()
removes matching records via rows_delete()
,
based on the primary key.
The order in which the tables are processed is reversed.
dm_rows_insert(x, y, ..., in_place = NULL, progress = NA) dm_rows_append(x, y, ..., in_place = NULL, progress = NA) dm_rows_update(x, y, ..., in_place = NULL, progress = NA) dm_rows_patch(x, y, ..., in_place = NULL, progress = NA) dm_rows_upsert(x, y, ..., in_place = NULL, progress = NA) dm_rows_delete(x, y, ..., in_place = NULL, progress = NA)
dm_rows_insert(x, y, ..., in_place = NULL, progress = NA) dm_rows_append(x, y, ..., in_place = NULL, progress = NA) dm_rows_update(x, y, ..., in_place = NULL, progress = NA) dm_rows_patch(x, y, ..., in_place = NULL, progress = NA) dm_rows_upsert(x, y, ..., in_place = NULL, progress = NA) dm_rows_delete(x, y, ..., in_place = NULL, progress = NA)
x |
Target |
y |
|
... |
These dots are for future extensions and must be empty. |
in_place |
Should When |
progress |
Whether to display a progress bar, if |
A dm object of the same dm_ptype()
as x
.
If in_place = TRUE
, the underlying data is updated as a side effect,
and x
is returned, invisibly.
# Establish database connection: sqlite <- DBI::dbConnect(RSQLite::SQLite()) # Entire dataset with all dimension tables populated # with flights and weather data truncated: flights_init <- dm_nycflights13() %>% dm_zoom_to(flights) %>% filter(FALSE) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(FALSE) %>% dm_update_zoomed() # Target database: flights_sqlite <- copy_dm_to(sqlite, flights_init, temporary = FALSE) print(dm_nrow(flights_sqlite)) # First update: flights_jan <- dm_nycflights13() %>% dm_select_tbl(flights, weather) %>% dm_zoom_to(flights) %>% filter(month == 1) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(month == 1) %>% dm_update_zoomed() print(dm_nrow(flights_jan)) # Copy to temporary tables on the target database: flights_jan_sqlite <- copy_dm_to(sqlite, flights_jan) # Dry run by default: dm_rows_append(flights_sqlite, flights_jan_sqlite) print(dm_nrow(flights_sqlite)) # Explicitly request persistence: dm_rows_append(flights_sqlite, flights_jan_sqlite, in_place = TRUE) print(dm_nrow(flights_sqlite)) # Second update: flights_feb <- dm_nycflights13() %>% dm_select_tbl(flights, weather) %>% dm_zoom_to(flights) %>% filter(month == 2) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(month == 2) %>% dm_update_zoomed() # Copy to temporary tables on the target database: flights_feb_sqlite <- copy_dm_to(sqlite, flights_feb) # Explicit dry run: flights_new <- dm_rows_append( flights_sqlite, flights_feb_sqlite, in_place = FALSE ) print(dm_nrow(flights_new)) print(dm_nrow(flights_sqlite)) # Check for consistency before applying: flights_new %>% dm_examine_constraints() # Apply: dm_rows_append(flights_sqlite, flights_feb_sqlite, in_place = TRUE) print(dm_nrow(flights_sqlite)) DBI::dbDisconnect(sqlite)
# Establish database connection: sqlite <- DBI::dbConnect(RSQLite::SQLite()) # Entire dataset with all dimension tables populated # with flights and weather data truncated: flights_init <- dm_nycflights13() %>% dm_zoom_to(flights) %>% filter(FALSE) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(FALSE) %>% dm_update_zoomed() # Target database: flights_sqlite <- copy_dm_to(sqlite, flights_init, temporary = FALSE) print(dm_nrow(flights_sqlite)) # First update: flights_jan <- dm_nycflights13() %>% dm_select_tbl(flights, weather) %>% dm_zoom_to(flights) %>% filter(month == 1) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(month == 1) %>% dm_update_zoomed() print(dm_nrow(flights_jan)) # Copy to temporary tables on the target database: flights_jan_sqlite <- copy_dm_to(sqlite, flights_jan) # Dry run by default: dm_rows_append(flights_sqlite, flights_jan_sqlite) print(dm_nrow(flights_sqlite)) # Explicitly request persistence: dm_rows_append(flights_sqlite, flights_jan_sqlite, in_place = TRUE) print(dm_nrow(flights_sqlite)) # Second update: flights_feb <- dm_nycflights13() %>% dm_select_tbl(flights, weather) %>% dm_zoom_to(flights) %>% filter(month == 2) %>% dm_update_zoomed() %>% dm_zoom_to(weather) %>% filter(month == 2) %>% dm_update_zoomed() # Copy to temporary tables on the target database: flights_feb_sqlite <- copy_dm_to(sqlite, flights_feb) # Explicit dry run: flights_new <- dm_rows_append( flights_sqlite, flights_feb_sqlite, in_place = FALSE ) print(dm_nrow(flights_new)) print(dm_nrow(flights_sqlite)) # Check for consistency before applying: flights_new %>% dm_examine_constraints() # Apply: dm_rows_append(flights_sqlite, flights_feb_sqlite, in_place = TRUE) print(dm_nrow(flights_sqlite)) DBI::dbDisconnect(sqlite)
Use these methods without the '.dm_zoomed' suffix (see examples).
## S3 method for class 'dm_zoomed' unite(data, col, ..., sep = "_", remove = TRUE, na.rm = FALSE) ## S3 method for class 'dm_keyed_tbl' unite(data, ...) ## S3 method for class 'dm_zoomed' separate(data, col, into, sep = "[^[:alnum:]]+", remove = TRUE, ...) ## S3 method for class 'dm_keyed_tbl' separate(data, ...)
## S3 method for class 'dm_zoomed' unite(data, col, ..., sep = "_", remove = TRUE, na.rm = FALSE) ## S3 method for class 'dm_keyed_tbl' unite(data, ...) ## S3 method for class 'dm_zoomed' separate(data, col, into, sep = "[^[:alnum:]]+", remove = TRUE, ...) ## S3 method for class 'dm_keyed_tbl' separate(data, ...)
data |
object of class |
col |
For For |
... |
For For |
sep |
For For |
remove |
For For |
na.rm |
see |
into |
zoom_united <- dm_nycflights13() %>% dm_zoom_to(flights) %>% select(year, month, day) %>% unite("month_day", month, day) zoom_united zoom_united %>% separate(month_day, c("month", "day"))
zoom_united <- dm_nycflights13() %>% dm_zoom_to(flights) %>% select(year, month, day) %>% unite("month_day", month, day) zoom_united zoom_united %>% separate(month_day, c("month", "day"))