mini\Table\Wrappers\CrossJoinTable class

Documentation

Cross join (Cartesian product) of two tables

Yields every combination of rows from both tables. Pure cartesian product - no join conditions.

For joins with conditions, VirtualDatabase should use InnerJoinTable instead.

// SELECT * FROM users CROSS JOIN products
new CrossJoinTable($users, $products)

Inheritance

Extends: mini\Table\AbstractTable

Implements: mini\Table\Contracts\SetInterface IteratorAggregate Countable Traversable mini\Table\Contracts\TableInterface

Properties (5)

protected ?Closure $compareFn
protected ?int $limit
protected int $offset

Methods (38)

Documentation missing

Documentation missing

Merge two rows into a single object

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Push a filter operation to the appropriate source table

Create new join with filtered source tables, preserving limit/offset

Hook for subclasses to customize clone behavior

Get column name(s) that the row key represents

Get the string comparison function for sorting

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Documentation missing

Get the current table alias (null if not set)

Documentation missing

Documentation missing

Documentation missing

Filter rows matching any of the given predicates (OR semantics)

Documentation missing

Check if value(s) exist in the table's projected columns

Get the primary key column definition (cached)

Iterate over rows with visible columns only

Get columns available for output

Get all column definitions regardless of projection

Narrow to specific columns

Load a single row by its row ID

Get a property value

Check if a property exists (including null values)

Return table with property set

Source

src/Table/Wrappers/CrossJoinTable.php:25-191