HEX
Server: Apache
System: Linux p3plzcpnl506847.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: slfopp7cb1df (5698090)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/slfopp7cb1df/public_html/inventorypacket.com/vendor/doctrine/dbal/src/Query/SelectQuery.php
<?php

namespace Doctrine\DBAL\Query;

final class SelectQuery
{
    private bool $distinct;

    /** @var string[] */
    private array $columns;

    /** @var string[] */
    private array $from;

    private ?string $where;

    /** @var string[] */
    private array $groupBy;

    private ?string $having;

    /** @var string[] */
    private array $orderBy;

    private Limit $limit;

    private ?ForUpdate $forUpdate;

    /**
     * @internal This class should be instantiated only by {@link QueryBuilder}.
     *
     * @param string[] $columns
     * @param string[] $from
     * @param string[] $groupBy
     * @param string[] $orderBy
     */
    public function __construct(
        bool $distinct,
        array $columns,
        array $from,
        ?string $where,
        array $groupBy,
        ?string $having,
        array $orderBy,
        Limit $limit,
        ?ForUpdate $forUpdate
    ) {
        $this->distinct  = $distinct;
        $this->columns   = $columns;
        $this->from      = $from;
        $this->where     = $where;
        $this->groupBy   = $groupBy;
        $this->having    = $having;
        $this->orderBy   = $orderBy;
        $this->limit     = $limit;
        $this->forUpdate = $forUpdate;
    }

    public function isDistinct(): bool
    {
        return $this->distinct;
    }

    /** @return string[] */
    public function getColumns(): array
    {
        return $this->columns;
    }

    /** @return string[] */
    public function getFrom(): array
    {
        return $this->from;
    }

    public function getWhere(): ?string
    {
        return $this->where;
    }

    /** @return string[] */
    public function getGroupBy(): array
    {
        return $this->groupBy;
    }

    public function getHaving(): ?string
    {
        return $this->having;
    }

    /** @return string[] */
    public function getOrderBy(): array
    {
        return $this->orderBy;
    }

    public function getLimit(): Limit
    {
        return $this->limit;
    }

    public function getForUpdate(): ?ForUpdate
    {
        return $this->forUpdate;
    }
}