File "SelectQuery.php"
                                Full Path: /home/pulsehostuk9/public_html/invoicer.pulsehost.co.uk/vendor/doctrine/dbal/src/Driver/API/MySQL/SelectQuery.php
                File size: 1.57 KB
                MIME-type: text/x-php
                Charset: utf-8
            
<?php
declare(strict_types=1);
namespace Doctrine\DBAL\Query;
final class SelectQuery
{
    /**
     * @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(
        private readonly bool $distinct,
        private readonly array $columns,
        private readonly array $from,
        private readonly ?string $where,
        private readonly array $groupBy,
        private readonly ?string $having,
        private readonly array $orderBy,
        private readonly Limit $limit,
        private readonly ?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;
    }
}