mini\Table\Wrappers\LeftJoinTable class

Documentation

Left join of two tables with ON condition

Yields all left rows, with matching right rows merged. Unmatched left rows have NULL for all right columns. Uses property-based binding: left table must have 'bind' property with Predicate.

// SELECT * FROM users u LEFT JOIN orders o ON u.id = o.user_id
new LeftJoinTable(
    $users->withAlias('u')->withProperty('__bind__', p->eqBind('u.id', ':o.user_id')),
    $orders->withAlias('o')
)

Inheritance

Extends: mini\Table\AbstractTable

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

Properties (8)

private mini\Table\Predicate $bindPredicate
private array $bindParams
private array $rightColNames
protected ?Closure $compareFn
protected ?int $limit
protected int $offset

Methods (40)

Documentation missing

Documentation missing

Extract binding values from a right row

Merge two rows into a single object

Merge left row with NULL values for right columns

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 bind and 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/LeftJoinTable.php:28-273