This method is equivalent to a database join on two tables, and the merge can be by common column or row names. It supports the equivalent of inner, left-outer, right-outer, and full-outer join operations. This method is similar to merge.data.frame.
# S4 method for db.obj,db.obj
merge(x, y, by = intersect(names(x), names(y)),
by.x = by, by.y = by, all = FALSE, all.x = all, all.y = all,
key = x@.key, suffixes = c("_x","_y"), ...)
The signature of the method. Both argument are db.obj
objects, and their associated tables will be merged.
specifications of the columns used for merging. See 'Details'.
logical; all = L
is shorthand for all.x = L
and all.y = L
, where L
is either TRUE
or FALSE
.
logical; if TRUE
, then extra rows will be added to the output, one for each row in x
that has no matching row in y
. These rows will have NA
s in those columns that are usually filled with values from y
. The default is FALSE
, so that only rows with data from both x
and y
are included in the output.
logical; analogous to all.x
.
specifies the primary key of the newly created table.
a character vector of length 2 specifying the suffixes to be used for making unique the names of columns in the result which not used for merging (appearing in by
etc).
arguments to be passed to or from methods.
See merge.data.frame. Note that merge.data.frame
supports an incomparables
argument, which is not yet supported here.
merge.data.frame
a merge operation for two data frames.
# NOT RUN {
<!-- %% @test .port Database port number -->
<!-- %% @test .dbname Database name -->
## set up the database connection
## Assume that .port is port number and .dbname is the database name
cid <- db.connect(port = .port, dbname = .dbname, verbose = FALSE)
## create sample databases
authors <- data.frame(
surname = I(c("Tukey", "Venables", "Tierney", "Ripley", "McNeil")),
nationality = c("US", "Australia", "US", "UK", "Australia"),
deceased = c("yes", rep("no", 4)))
books <- data.frame(
name = I(c("Tukey", "Venables", "Tierney",
"Ripley", "Ripley", "McNeil", "R Core")),
title = c("Exploratory Data Analysis",
"Modern Applied Statistics ...",
"LISP-STAT",
"Spatial Statistics", "Stochastic Simulation",
"Interactive Data Analysis",
"An Introduction to R"),
other.author = c(NA, "Ripley", NA, NA, NA, NA,
"Venables & Smith"))
delete("books", conn.id = cid)
delete("authors", conn.id = cid)
as.db.data.frame(books, 'books', conn.id = cid, verbose = FALSE)
as.db.data.frame(authors, 'authors', conn.id = cid, verbose = FALSE)
## Cast them as db.data.frame objects
a <- db.data.frame('authors', conn.id = cid, verbose = FALSE)
b <- db.data.frame('books', conn.id = cid, verbose = FALSE)
## Merge them together
m1 <- merge(a, b, by.x = "surname", by.y = "name", all = TRUE)
db.disconnect(cid, verbose = FALSE)
# }
Run the code above in your browser using DataLab