| DataBackend | R Documentation | 
This is the abstract base class for data backends.
Data backends provide a layer of abstraction for various data storage systems. It is not recommended to work directly with the DataBackend. Instead, all data access is handled transparently via the Task.
This package currently shups with one implementation for backends:
DataBackendDataTable which stores the data as data.table::data.table().
To connect to out-of-memory database management systems such as SQL servers, see the extension package mlr3db.
The required set of fields and methods to implement a custom DataBackend is
listed in the respective sections (see DataBackendDataTable).
primary_key(character(1))
Column name of the primary key column of positive and unique integer row ids.
hash(character(1))
Hash (unique identifier) for this object.
col_hashes(named character)
Hash (unique identifier) for all columns except the primary_key: A character vector, named by the columns that each element refers to.
Columns of different Tasks or DataBackends that have agreeing col_hashes always represent the same data, given that the same rows are selected.
The reverse is not necessarily true: There can be columns with the same content that have different col_hashes.
new()Creates a new instance of this R6 class.
Note: This object is typically constructed via a derived classes, e.g.
DataBackendDataTable, or via the S3 method
as_data_backend().
DataBackend$new(data, primary_key)
data(any)
The format of the input data depends on the specialization. E.g.,
DataBackendDataTable expects a data.table::data.table().
primary_key(character(1))
Each DataBackend needs a way to address rows, which is done via a
column of unique integer values, referenced here by primary_key. The
use of this variable may differ between backends.
format()Helper for print outputs.
DataBackend$format(...)
...(ignored).
print()Printer.
DataBackend$print()
Chapter in the mlr3book: https://mlr3book.mlr-org.com/chapters/chapter10/advanced_technical_aspects_of_mlr3.html#sec-backends
Package mlr3db to interface out-of-memory data, e.g. SQL servers or duckdb.
Other DataBackend: 
DataBackendDataTable,
as_data_backend()
data = data.table::data.table(id = 1:5, x = runif(5),
  y = sample(letters[1:3], 5, replace = TRUE))
b = DataBackendDataTable$new(data, primary_key = "id")
print(b)
b$head(2)
b$data(rows = 1:2, cols = "x")
b$distinct(rows = b$rownames, "y")
b$missings(rows = b$rownames, cols = names(data))
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.